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Preliminary Data Sheet 


FEATURES 


Microcontroller interface 


= Supports high-speed microcontroller interfaces 
(e.g., 16 MHz 80188, 12 MHz 68HC11, 30 MHz 
HPC460x3) 


m Supports direct microcontroller access to the SCSI 
Bus, buffer memory, and external switches 


= Supports separate host and disk interrupt struc- 
tures for flexible interrupt or polled firmware design 


SCSI Interface 
= Supports SCSI-2 Initiator and Target modes 


m@ Supports asynchronous DMA/P1O transfers up to 3 
Mbytes/second 


Supports synchronous DMA/PIO transfers up to 5 
Mbytes/second 


Supports up to 15-byte synchronous transfer off- 
sets and 12 programmable transfer periods 
Controls synchronous transfer overrun/underrun 


Transfers SCSI information to/from the microcon- 
troller through a 16-byte FIFO under Automatic 
Programmed 1/0 (PIO) 


Controls arbitration, selection, and reselection in 
hardware 


Detects selected and reselected conditions auto- 
matically 


(cont. next page) 
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OVERVIEW 


The CL-SM331 is a VLSI component designed to 
work with the CL-SM330 ECC/ENDEC to provide 
the majority of the hardware necessary to build a 
Small Computer System Interface (SCSI) Optical 
disk controller. The CL-SM331 design combines: 
a high-speed local microcontroller port, extensive 
hardware support for the SCSI Interface, a two- 
channel Buffer Manager, and an advanced Sector 
Formatter. With the addition of only a few discrete 
components for the device-level interface, the CL- 
SM331 and the CL-SM330 along with a local 
microcontroller, system ROM and RAM, and an 
optional data separator completes an optical disk 
controller subsystem with high performance at a 
low overall cost. 


A local microcontroller provides the CL-SM331 
with initial operating parameters that include disk 
sector format, the type and size of buffer memory, 
and SCSI Host Control. During data transfer 
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FEATURES ( cont.) 


m Integrates 48 mA SCSI Bus drivers in the interface 


m Providescontrol forthe external differential driver 
option 


Sector Formatter 
m= Supports up to 24 MHz NRZ data rates 


m= Programmable Format Sequencer Writable Control 
Store (WCS-31 x 4 bytes) 


w Offers advanced branch commands thatautomate 
retry algorithms 


Buffer Manager 


= Dual channel circular buffer control with priority 
resolution 

m= Direct bufferaddressing up to 256K bytes of SRAM 
and 4 Mbytes of DRAM 


CL-SM331 


SCSI Optical Disk Controller 


m= Permits concurrent buffer memory throughput up 
to 10 Mbytes/second in DRAM page mode and 12 
Mbytes/second for SRAM 

mw Odd parity data verification between the SCSI Bus 
and the Sector Formatter 

m Automatically accepts and processes ECC 
correction vectors from companion optical ENDEC/ 
ECC (CL-SM330) Integrated Circuit 


Technology 
m 100-pin Quad Flat Pack (QFP) package 


m Pinout organized for optimum board layout 
efficiency 


m Advanced, low-power double metal CMOS 
technology 


OVERVIEW cont.) 


operations, the CL-SM331 requires only minimal 
intervention from the local microcontroller. The 
microcontroller to CL-SM331 communication path 
is amultiplexed address and data bus similar to that 
provided by the Intel® 80188 and the Motorola® 
68HC11 class of controllers. There is a configuration 
signal available to allow for either family of data 
control signal methods. The CL-SM331 has 
centralized status registers with interrupt capability. 
These features allow firmware designers flexibility 
in writing polled loops or interrupt handlers that 
provide real-time process control critical in embedded 
controller drive applications. 


The SCSI Host Interface is designed for compliance 
with the proposed SCSI-2 specification. This ensures 
long-term compatibility for both the hardware and 
the firmware developed around the CL-SM331. The 
SCSI Interface logic includes integrated high current 
(48 mA) drivers for the single-ended option as well 
as signals for control of the external logic necessary 
to implement the differential transceiver option. 
Both the asynchronous and synchronous transfer 
protocols are supported in either Initiator or Target 
mode. Routine bus control operations such as 
arbitration, selection, and reselection are 


automatically sequenced in hardware. This method 
of implementing the SCSI Interface makes the SCS| 
protocol firmware extremely flexible and very efficient. 


The Sector Formatter provides the disk data and 
control functions. The Sector Formatter is capable 
of handling NRZ data rates up to 24 Mbits/second. 
The Sector Formatter is subdivided into a Format 
Sequencer and the Sector Formatter Data path. 
The Format Sequencer uses a 31-word-by-4-byte 
Writable Control Store (WCS) to hold a user-written 
program. This program contains the control 
information for the disk track and sector format. The 
Sector Formatter Data path consists of the NRZ 
data handling circuitry that includes the serializer/ 
deserializer (SERDES), the SERDES parity logic, 
and the data signals to the Buffer Manager Interface. 


The Buffer Manager controls the flow of databetween 
the host and disk interfaces. These interfaces store 
and retrieve data from the buffer memory using 
interleaved access cycles. The actual buffer memory 
may be implemented with static or dynamic RAM 
devices. The CL-SM331 Buffer Manager is 
programmable to provide all of the necessary address 
and control signals for RAM devices of varying 
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OVERVIEW cont.) 


access times. Up to 256K bytes of SRAM can be 
directly addressed by the CL-SM331. As much as 
4 Mbytes of DRAM is directly supported by the CL- 
SM331 with specific control for 64K, 256K, 1Mbit 
and 4 Mbit devices. In DRAM mode, refresh is 
generated automatically through a third channel to 


ADVANTAGES 


Unique Features: 
m Programmable wait states for microcontroller 


= Pin-configurable microcontroller data control 
interface 


m Separate disk and host microcontroller 
interrupts 


m 15-byte offset in synchronous mode 

m 16-byte FIFO for automatic PIO transfers 

mw External differential SCSI Bus support 

= Two Buffer Manager DMA channels 

m Direct 256K SRAM and 4 Mbytes DRAM 
addressing 


m Odd-through-parity buffer verification 


m 64K buffer segmentation logic 
m Programmable read synchronization time-out 
m Full hardware support for processing ECC 


correction vectors supplied by companion 
CL-SM330 


i 
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the buffer memory in addition to the concurrent disk 
andhostaccesses. The CL-SM331 Buffer Manager 
will accept hardware ECC correction vectors from 
the CL-SM330 optical ENDEC/ECC Integrated 
Circuit and automatically correct errors in the buffer 
RAM within one sector time. 


Benefits: 


og Allows the fastest microcontrollers to operate 
without degrading bus performance 


o Allows for direct connect to Intel-or Motorola- 
style microcontrollers 


o Supports faster, more direct interrupt 
processing by microcontroller 


o Greater flexibility for synchronous data 
transfer negotiations 


o Decreases command and information transfer 
overhead 


g §©Allows connection to any SCSI system with 
longer cable lengths 


o Enables read-look-ahead for high 
performance 


oO Increases buffer size alternatives to support 
caching 


o Improves data integrity between host and disk 
data transfers 


0 ©6Allows protected data segments in buffer 


ag Provides real-time processing of 
synchronization windows 


o Automatic error correction within one sector 
time without microcontroller intervention 
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1. PIN INFORMATION 
The CL-SM331 is available in a 100-pin Quad Flat Pack (QFP) package. The diagram below 
shows the pinout of this package. All unused inputs must be tied to the inactive state to VCC 
or GND, respectively. 

1.1. Pin Diagram for the 100-Pin Quad Flat Pack (QFP) Package 
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rae PIN ASSIGNMENTS 


The following conventions are used in the pin assignment tables. An asterisk (*) denotes a 
negative true signal. An (I) indicates an input pin. An (O) indicates an output pin. An input/ 
output pin is indicated by (I/O). A (Z) indicates a tri-state output. Open drain output pins are 
indicated by (OD). All unused inputs must be tied to the inactive state to VCC or GND, 
respectively. 


2.1 Microcontroller Interface Pins 


QFP PIN 

SYMBOL NUMBER TYPE DESCRIPTION 

DINT 32 O,OD,Z DISK INTERRUPT: This signal is a disk interrupt line 
to the microcontroller, and is programmable for either a 
push-pull or open-drain output circuit. This signal powers 
up in the high-impedance state. 

CS0* 34 | CHIP SELECT 0, 1: Either chip select signal O or 1 

CS1* 35 must be asserted low for the microcontroller accesses to 


the CL-SM331 registers and to the Writable Control Store 


(WCS). Unused chip select pin must be tied to high. 


WR*/RIW* 36 | WRITE STROBE/READ/WRITE: When the Intel Bus 
Control Interface is selected (the I/MC* Signal (Pin 40) is 
asserted high), this signal acts as the WR* Signal. When 
the Write Strobe Signal is asserted low and the CS* 
Signal (Pin 34 or 35) is asserted low, the data on the A/D 
lines will be written to the specified register. 


When the Motorola Bus Control Interface is selected (the 
I/MC* Signal (Pin 40) is deasserted low), this signal acts 
as the R/W* Signal. A high on this input along with the 
RD*/DS Signal (Pin 37) asserted and the CS* Signal 
(Pin 34 or 35) asserted low indicates a read operation. A 
low on this input along with the RD*/DS Signal (Pin 37) 
asserted and the CS*Signal (Pin 34 or 35) asserted low 
indicates a write operation. 
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2.1 Microcontroller Interface Pins (cont.) 


QFP PIN 
SYMBOL NUMBER TYPE DESCRIPTION 


RD*/DS 37 | READ STROBE/DATA STROBE: When the Intel Bus 
Control Interface is selected (the I/MC* Signal (Pin 40) is 
asserted high), this signal acts as the RD* Signal. When 
the Read Strobe Signal is asserted low and the CS* 
Signal (Pin 34 or 35) is asserted high, the data from the 
specified register will be driven onto the A/D lines. 


When the Motorola Bus Control Interface is selected (the 
I/MC* Signal (Pin 40) is deasserted low), this signal acts 
as the DS Signal. A high on the R/W* Signal along with 
this signal asserted and the CS* Signal (Pin 34 or 35) 
asserted high indicates a read operation. A low on the 
R/W* Signal along with this signal asserted and the CS* 
Signal (Pin 34 or 35) asserted high indicates a write 
operation. 


READY 38 OD READY: This is the microcontroller ready line. When 
this is deasserted low, the microcontroller shall insert wait 
states to allow time for the CL-SM331 to respond to the 
access. 


I/MC* 40 | INTEL/MOTOROLA: This signal selects the 
microcontroller interface to be used. When this signal is 
asserted high, it selects the Intel Bus Control Interface. 
When this signal is deasserted low, it selects the 
Motorola Bus Control Interface. This input signal may be 
legally ‘floated’ with the default selection of the Intel Bus 
Control Interface. 


HINT 33 O, OD, Z HOST INTERRUPT: This signal is a Host Interrupt line 
to the microcontroller. It is programmable for either a 
push-pull or open-drain output circuit. This signal powers 


up in the high-impedance state. 


ADO:7 42-44, 1@) LOCAL MICROCONTROLLER ADDRESS/ DATA 
46-50 BUS: These are tri-state Address/Data lines that 
interface with a multiplexed Microcontroller Address/Data 
Bus. 
ALE 52 | ADDRESS LATCH ENABLE: The trailing edge of this 


control signal latches the address on the A/D lines. 


RST* 19 | RESET: An asserted low input generates a component 
reset that stops all operations within the chip and 
deasserts all output signals. All input/output signals, the 
SCSI Interface Output signals and the HINT Signal (Pin 
33) and the DINT Signal (Pin 32) are set to the high- 
impedance state. Refer to the section on register 
initialization (Section 5.3). 
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2.2 SCSI Bus Interface Pins 


QFP PIN 

SYMBOL NUMBER TYPE - DESCRIPTION 

SDBO*:7* 54-57, VO,OD SCSI DATA BUS: These eight signals comprise 

59-62 the SCSI Data Bus for information transfer. 

SDBP* 63 /O,OD SCSI DATA BUS PARITY: This signal transfers odd 
parity of the SCSI Data Bus. 

ATN* 66 /O,OD SCSI ATTENTION: This signal indicates the Attention 
condition on the SCSI Bus. 

BSY* 67 VO,OD SCSI BUSY: This signal when asserted low indicates 
that the SCSI Bus is being used. 

ACK* 68 | VO SCSI ACKNOWLEDGE: When this signal is asserted 
low, it indicates that the SCSI Initiator has acknowledged 
the data transfer. 

SRST* 69 /O,OD SCSI RESET: This signal when asserted low indicates 
that the Reset Condition is on the SCSI Bus. 

MSG* 70 /0,OD SCSI MESSAGE: When this signal is asserted low, it 
indicates that the SCSI Message Phase is active on the 
SCSI Bus. | 

SEL" 72 VO,OD SCSI SELECT: This signal is used by a SCSI Initiator 


to select a SCSI Target or by a SCSI Target to reselect a 
SCSI Initiator. 


C*/D 73 /0O,OD SCSI COMMAND/DATA: This signal indicates 
whether Control (when asserted low), or Data (when 
deasserted high) information is on the SCSI Data Bus 


signals. 

REQ* 74 VO SCSI REQUEST: This signal when asserted low 
indicates that a request for a data transfer is active on the 
SCSI Bus. 

I/O 75 /O,OD SCSI INPUT/OUTPUT: This signal controls the 


direction of data transfer on the SCSI Data Bus signals 
with respect to a SCSI Initiator. When this signal is 
asserted low, it indicates information input to the SCSI 
Initiator. When this signal is deasserted high, it indicates 
output from the SCSI Initiator. This signal is also used to 
distinguish between the SCSI Selection and the SCSI 
Reselection phases. 
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2.3 SCSI Bus Control Pins 
QFP PIN 
SYMBOL NUMBER TYPE DESCRIPTION 
SDOE 78 O SCSI DATA BUS OUTPUT ENABLE: This signal is 
asserted high when the SCSI Data Bus is to be driven by 
| the CL-SM331. 
INIT 79 O INITIATOR: When this signal is asserted, it indicates 
that the CL-SM331 is an Initiator device active on the 
SCSI Bus. 
TAR 81 O TARGET: When this signal is asserted, it indicates that 
the CL-SM331 is a Target device active on the SCSI Bus. 
AIP 82 O ARBITRATION IN PROGRESS: When this signal is 


asserted, it indicates that the CL-SM331 is in the SCSI 
Arbitration Phase. 


BSYO 80 O BUSY OUT: This is the SCSI Busy Output Signal. 
When this signal is asserted, it indicates that the CL- 


SM331 is driving the SCSI Busy Signal (Pin 67). 


SELO 76 O SELECT OUT: This is the SCSI Select output Signal. 
When it is asserted, it indicates that the CL-SM331 is 
driving the SCSI Select Signal (Pin 72). 
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2.4 Buffer Manager Interface Pins 
QFP PIN 
SYMBOL NUMBER TYPE ' DESCRIPTION 
BA17/CAS* 15 O BUFFER MEMORY ADDRESS 17/COLUMN 


ADDRESS ' STROBE: This signal is used for 
addressing the buffer memory in SRAM Mode or as the 
column address strobe in DRAM Mode. 


BA16/RAS* 14 O BUFFER MEMORY ADDRESS 16/ROW 
ADDRESS STROBE: This signal is used for 
addressing the buffer memory in SRAM Mode or as the 
row address strobe in DRAM Mode. 


MOE* 16 O MEMORY OUTPUT ENABLE: In SRAM Mode this 
signal is asserted low when every buffer memory access 
is active. It is recommended that this signal be connected 
to the SRAM Output enable for high-speed operation. In 
DRAM Mode this signal is asserted low only for buffer 
memory read operations. 


WE* 17 O WRITE ENABLE: This signal is asserted low when a 
buffer memory write operation is active in both SRAM and 
DRAM Modes. 

SYSCLK 24 | SYSTEM CLOCK: This is the clock input that is used 


to generate buffer memory access cycles, to control 
automatic SCSI timing operations, and to clock ECC 
Correction Vector processes. 


BDO:7 84-88, VO BUFFER MEMORY DATA BUS: These eight signals 
90,93-94 are Bits 0-7 of the eight-bit parallel data lines to/ from the 

buffer memory. 
BDP 95 VO BUFFER MEMORY DATA PARITY: This signal 


transfers odd parity of the Buffer Memory Data Bus 
to/from the buffer memory. 


BAO:15 96-99 O BUFFER MEMORY ADDRESS LINES: These 
1-8, 10-13 are signals 0-15 for addressing the buffer memory. 
VECTOR 23 | ECC CORRECTION VECTOR: This signal accepts 
ECC correction vector packets from the companion CL- 
SM330. 
VERROR 21 O ECC CORRECTION VECTOR ERROR: This signal is 


asserted if either the ECC Correction Vector packet was 
received with a protocol error or if the correction process 
was not successful. 


VREADY 22 O ECC CORRECTION VECTOR READY: This signal is 
asserted if the ECC Correction Circuit is ready to accept 
an ECC Correction Vector packet. 
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2.5 Sector Formatter Interface Pins 
QFP PIN 
SYMBOL NUMBER TYPE DESCRIPTION 
SMDET 18 | SECTOR MARK DETECTED: This is the input for the 
sector pulse received from the disk drive. 
IDF 31 | FORMAT SEQUENCER INPUT: This input signal is 
| available to synchronize the Format Sequencer to an 
external event. 
SRG 25 O SYSTEM READ GATE: This signal is asserted when 
a disk read operation is in progress, and the NRZ Data is 
input to the CL-SM331. 
SWG 26 O SYSTEM WRITE GATE: This signal is used to enable 
the writing of NRZ Data out to the storage device during a 
write operation. 
RRCLK 28 | READ REFERENCE CLOCK: This signal input clocks 
the NRZ Data. 
NRZ 29 1@) NON RETURN TO ZERO: This signal is the read data 
input from the disk drive when the Read Gate Signal (Pin 
43) is asserted; it is the write data output to the disk drive 
when the Write Gate Signal (Pin 44) is asserted. 
OUTPUT 30 O FORMAT SEQUENCER OUTPUT: This output signal 
is available to synchronize the external hardware to the 
Format Sequencer. This signal is controlled by Bit 2 of 
the Control Field of the Writable Control Store (WCS). 
12 a Sa ES I RP PT TT I ETT EE April 1991 


CL-SM331 ———— 
SCSI Optical Disk Controller se CIRRUS LOGIC 


2.6 Power and Ground Pins 


QFP PIN 
SYMBOL NUMBER TYPE DESCRIPTION 


BGNDt 9,89,100 N/A BUFFER GROUND PINS. 
LGNDt 20, 27, N/A LOGIC GROUND PINS. 
41, 45 


+5V 39, 51, N/A POWER SUPPLY (+5V). 
91-92 


SGNDT 53, 58, N/A HIGH CURRENT SCSI GROUND PINS. 
64-65, 71 
77, 83 


NOTE: The superscript T indicates that SGND, BGND, and LGND are connected to three sep- 
arate ground rings internally. 
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3. REGISTER TABLES 


3.1 SCSI Interface Registers 
ADDRESS TYPE DESCRIPTION/FUNCTION 
40H/60H RW Direct SCSI Access Port 
41H/61H R Selection/Reselection ID Input 
41H/61H W Selection/Reselection ID Output 
42H/62H RW SCSI Phase Control 
43H/63H RW SCSI Synchronous Control 
44H/64H RW SCSI Mode Control 
45H/65H RW SCSI Operation Control 
46H/66H R/W SCSI Status Register 1 
47H/67H R/W SCSI Interrupt Enable Register 1 
48H RW SCSI Status Register 2 
49H R/W SCSI Interrupt Enable Register 2 
4AH RW Microcontroller SCSI FIFO Access Port 
3.2 Buffer Manager Registers 


ADDRESS TYPE DESCRIPTION/FUNCTION 


50H RW Scheduled Buffer Data 

51H RW Buffer Status/Control Register 
52H RW Buffer Transfer Control 

53H RW Buffer Mode Control 

54H RAW Buffer Manager Timing Control 
55H RW DRAM Refresh Period 

56H RW Buffer Size 

57H-59H RW Disk Address Pointer 
5AH-5CH RW Host Address Pointer 
5DH-5FH R/W Stop Address Pointer 
71H-73H R Vector Process Address Pointer 
74H R Vector Process Error Pattern 
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3.3 Sector Formatter Registers 


ADDRESS 
4EH 

4FH 

70H 
75H-76H 
77H 

78H 

78H 

79H 

79H 

7AH 
7BH-7CH 
7DH 

7EH 

7FH 

7FH 


TYPE 
RW 
RW 
RW 


so ae lal 


= "12/3 


DESCRIPTION/FUNCTION 
Sector Size 

Sector Formatter Mode Control 
Synchronization Byte-Count Limit 
Reserved 

Sector Formatter Operation Control 
Next Format Sequencer Address 
Branch Address 

Format Sequencer Status Register 1 
Format Sequencer Start Address 
Format Sequencer Status Register 2 
Reserved 

Sector Formatter Interrupt 

Sector Formatter Interrupt Enable 
Sector Formatter Stack 

Reserved 


3.4 Writable Control Store (WCS) Fields 


ADDRESS 
80H-9EH 
AOQH-BEH 
COH-DEH 
EQH-FEH 


TYPE 
RW 
RAW 
RW 
RW 


3.5 Sequencer Registers 


ADDRESS 
9FH 
BFH 
DFH 
FFH 


TYPE 
RAW 
RWW 
RAW 


DESCRIPTION/FUNCTION 
Next Address Field 

Control Field 

Count Field 

Data/Branch Field 


DESCRIPTION/FUNCTION 

Current Sequencer Word — Next Address Field 
Current Sequencer Word — Control Field 
Current Sequencer Word — Count Field 
Current Sequencer Word — Data/Branch Field 
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3.6 Register and Bit Table 


ADDRESS TYPE DESCRIPTION/FUNCTION 
40H/60H RWW Direct SCSI Access Port 
A1H/61H R Selection/Reselection ID Input 


41H/61H W | Selection/Reselection ID Output 
42H/62H RAW SCSI Phase Control 


Bit7: SCSI Acknowledge 
Bit6: SCSI Attention 
Bit5: SCSI Select 

Bit4: SCSI Busy 

Bit3: SCSI Request 
Bit2: SCSI Message 
Bit1: SCSI Input/Output* 
BitO: SCSI Control/Data* 


43H/63H RW SCSI Synchronous Control 


Bits 7-4: Synchronous Transfer Rate 
Bits 3-0: Offset Count 


44H/64H RW SCSI Mode Control 


Bits 7-5: SCSI Logic Clock Prescalar 
Bit 4: SCSI Logic Clock Disable 
Bit 3: SCSI Parity Enable 

Bits 2-0: SCSI ID Bits 


45H/65H RW SCSI Operation Control 


Bit7: SCSI Reset Out 

Bit6: SCSI Active Pull-up Select 

Bit5: Enable Initiator 

Bit4: Enable Target 

Bit3: Microcontroller Direct SCSI Output Enable 
Bit2: SCSI Automatic Selection/Reselection Mode 
Bit1: SCSI Automatic Selection/Reselection Enable 
BitO: Arbitration/Selection Start 


46H/66H RW SCSI Status Register 1 


Bit 7: SCSI Rest In 

Bit6: SCSI Parity Error 

Bit5: SCSI Bus Parity Error Detected 

Bit4: SCSI/Buffer Parity Error Detected 

Bit3: SCSI Bus Free Detected 

Bit2: SCSI Offset Overrun/Underrun Detected 
Bit1: SCSI Attention Detected 

BitO: SCSI Reset Detected 
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3.6 Register and Bit Table (cont.) 


ADDRESS TYPE DESCRIPTION/FUNCTION 


47H/67H RW SCSI Interrupt Enable Register 


Bits 7-6: Reserved 

Bit 5: SCSI Bus Parity Error Enable 
Bit 4: SCSI/Buffer Parity Error Enable 
Bit 3: SCSI Bus Free Detected Enable 
Bit 2: Offset Overrun/Underrun Enable 
Bit 1: Attention Detected Enable 

Bit 0: SCSI Reset Detected Enable 


48H RW SCSI Status Register 2 
Bit7: Req-On 
Bit6: SCSI Phase Mismatch 
Bit5: Transfer Halted 
Bit4: Transfer Done 
Bit3: | Automatic Selecting/Reselecting Done 
Bit2: Arbitration Won 
Bit1: Device Reselected 
BitO: Device Selected 


49H RW SCSI Interrupt Enable Register 2 


Bit7: |Req-On Enable 

Bit6: SCSI Phase Mismatch Enable 

Bit5: Transfer Halted 

Bit4: Transfer Done Enable 

Bit3: Automatic Selecting/Reselecting Enable 
Bit2: Arbitration Won Enable 

Bit1: Device Reselected Enable 

BitO: Device Selected Enable 


4AH RW ~~ Microcontroller SCSI FIFO Access Port 
4BH-4DH Reserved 

4EH RW = Sector Size 

4FH RW Sector Formatter Mode Control 


Bit7: Reserved 

Bit6: Local Int* Mode Enable 

Bit5: Interrupt Polarity 

Bit4: SCSI Interface Register Decode Select 
Bit3: Local Int* Pin Pull-up Disable 

Bit2: Local Dint Enable 

Bit1: Local Hint Enable 

BitO: Sector Formatter Reset 


50H RW Scheduled Buffer Data 
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3.6 Register and Bit Table (cont.) 


ADDRESS TYPE DESCRIPTION/FUNCTION 


51H RW ~~ Buffer Status/Control Register 

Bit7: Reserved 

Bit 6: DRAM Burst Enable 

Bit 5: SCSI Data Set Up Select 

Bit 4: Clear FIFO 

Bits 3-0: Synchronous Data Transfer Offset (Read Only) 
52H RW Buffer Transfer Control 

Bits 7-4: PIO Transfer Count 

Bit 3: SCSI R/W* Transfer Direction 

Bit 2: PIO Start 

Bit 1: DMA Start 

| Bit 0: Enable Buffer Segmentation | 

53H RW ~~ Buffer Mode Control 

Bits 7-6: Wait States 

Bit 5: Host/Buffer Reset 

Bit 4: MOE Disable 

Bit 3: Buffer Memory Parity Enable 

Bits 2-1: DRAM Type 

Bit 0: DRAM/SRAM* 


54H R/W Buffer Manager Timing Control 
Bits 7-6: CAS* High Time 
Bits 5-4: CAS* Low Time 
Bits 3-2: RAS* High Time 
Bits 1-0: RAS* Low Time/SRAM Cycle Time 


55H RAV DRAM Refresh Period 
56H RW = Buffer Size 

57H-59H RW _ Disk Address Pointer 
5AH-5CH RW _-~ Host Address Pointer 
5DH-5FH RW ~~ Stop Address Pointer 


70H RW = Synchronization Byte-Count Limit 
71H-73H R Vector Process Address Pointer 
74H R Vector Process Error Pattern 
75H-76H Reserved 
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ADDRESS TYPE DESCRIPTION/FUNCTION 


77H RW Sector Formatter Operation Control 
Bits 7-6: Reserved 
Bit 5: Edge Detect Sensitivity Selection 
Bit 4: Inhibit Data Field Carry 
Bit 3: Buffer/Disk R/W* Transfer Direction 
Bit 2: Suppress Transfer 
Bit 1: Data/Branch Field Mode Enable 
Bit 0: Reserved 
78H R Next Format Sequencer Address 
Bits 7-5: Reserved 
Bits 4-0: Next Active Format Sequencer Address 
78H W Branch Address 
Bits 7-5: Reserved 
Bits 4-0: Branch Address 
79H R Format Sequencer Status Register 1 
Bit 7: Byte Ready 
Bit 6: Format Sequencer Output 
Bit 5: Format Sequencer Input 
Bit 4: Synchronization Detect Status 
Bit 3: Branch Active 
Bit 2: Data Transfer 
Bit 1: AM Active 


Bit 0: Format Sequencer Active 


79H W Format Sequencer Start Address 
Bits 7-5: Reserved 
Bits 4-0: Start Address 
7AH R Format Sequencer Status Register 2 
Bit 7: Reserved 
Bit 6: Disk/Buffer Parity Error 
Bit 5: Reserved 
Bit4: § Synchronization Time-Out Error 
Bit 3: Data Field CRC Error 
Bit 2: Compare Less Than 
Bit 1: Compare Greater Than 
Bit 0: Compare Equal 
7BH-7CH Reserved 
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Register and Bit Table (cont.) 
ADDRESS TYPE DESCRIPTION/FUNCTION 


7DH 


7EH 


80H-9EH 


9FH 
AQH-BEH 


BFH 
COH-DEH 


DFH 
EQH-FEH 
FFH 


RWW 


RW 


RW 


RAW 


RAW 


Sector Formatter Interrupt | 


Bit 7: Vector Parity Error Detected 

Bit6: | Sequencer Output Detected 

Bit 5: Data Transfer Detected 

Bit 4: Branch Active Detected 

Bit3: | Sequencer Stopped Detected 

Bit 2: Input Detected 

Bit 1: Vector Transmission Error Detected 
Bit 0: SMDET Detected 


Sector Formatter Interrupt Enable 


Bit 7: Vector Parity Error Detected Enable 

Bit 6: Sequencer Output Detected Enable 

Bit 5: Data Transfer Detected Enable 

Bit 4: Branch Active Detected Enable 

Bit 3: Sequencer Stopped Detected Enable 

Bit 2: Input Detected Enable 

Bit 1: Vector Transmission Error Detected Enable 
Bit 0: SMDET Detected Enable 


Sector Formatter Stack 
Reserved 


WCS Next Address Field 


Bits 7-5: Branch Command 
Bits 4-0: Next Address 


Current Sequencer Word — Next Address Field 


WCS Control Field 


Bit 7: Alternate Branch Command Select 
Bits 6-5: Control Field 


Bit 4: Stack Enable 

Bit 3: Invalid NRZ Control 
Bit 2: Output 

Bit 1: Compare Enable 
Bit 0: Data Transfer 


Current Sequencer Word — Control Field 


WCS Count Field 


Bit 7: Count/Process AM 
Bit 6: Count/Process CRC/Start Synchronization Timer 
Bits 5-0: Count 


Current Sequencer Word — Count Field 
WCS Data/Branch Field 
Current Sequencer Word — Data/Branch Field 
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4. FUNCTIONAL DESCRIPTION 


Within high-performance, intelligent, disk drive 
controller subsystems the CL-SM331 is the 
VLSI component that enables the local 
microcontroller to off load all of the disk 
controller real-time tasks. Consequently, the 
microcontroller can execute commands at a 
higher level by parsing the command into lower 
level, high-speed tasks. These lower level, 
high-speed tasks are in turn completely 
managed by the CL-SM331. 


As the block diagram on the cover page 
indicates, the components can be divided into 
the following four functional blocks: 


¢ Microcontroller, 
¢ SCSI Host, 

¢ Buffer Manager, and 
¢ Sector Formatter. 


Each of these functional logic blocks has an 
associated interface that is specifically designed 
to manage the operation of the external devices 
and buses. In order to provide this support each 
interface uses information that is programmed 
by the local microcontroller in advance of the 
required operations. 


4.1 Microcontroller Interface 


A number of features have been included in the 
Microcontroller Interface to enable the CL- 
5M331 to operate with a variety of high-speed 
microcontrollers. For example, the CL-SM331 
has a configuration signal called the !/MC* 
Signal (Pin 40) that allows for either the Intel or 
the Motorola method of data control to be used. 
Through the CL-SM331 Microcontroller 
Interface all of its registers are read or written, 
and the Writable Control Store (WCS) is 
programmed for the required operations of any 
sector and track format. 
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4.1.1 Microcontroller Interface to the CL- 
SM331 


The microcontroller to CL-SM331 
communication path is a multiplexed, 8-bit 
address and Data Bus similar to that provided 
by the Intel 80188 and the Motorola 68HC11 
class of controllers. The CL-SM331 can use 
either the Intel or the Motorola method of data 
control. If the I/MC* Configuration Signal (Pin 
40) is connected to power, or is left unconnected 
then the component uses the Intel method of 
data control. When the Intel Interface is 
selected, the WR*/R/W* Signal (Pin 36) acts as a 
write strobe. In the case of a write operation, 
this write strobe provides the timing and control 
for the data transfers. Similarly in the case of a 
read operation, the RD*/DS Signal (Pin 37) acts 
as a read strobe to provide the timing and the 
control for the data transfers. 


If the I/MC* Signal (Pin 40) is connected to 
ground then the Motorola Interface is assumed. 
This configuration converts the WR*/R/W* Signal 
(Pin 36) into a control signal that is used only to 
determine the direction of the data transfer. 
When the input to this signal is high, a read 
operation is in progress; when it is low, a write 
operation is in progress. Data timing is derived 
with respect to the RD*/DS Signal (Pin 37). In 
the case of a read operation, the rising (leading) 
edge of the RD*/DS Signal (Pin 37) indicates 
when the CL-SM331 can start driving the Data 
Bus. In the case of a write operation, the falling 
(trailing) edge is used by the CL-SM331 to latch 
the data from the Microcontroller Address/Data 
Bus. 


The CL-SM331 can also generate wait states to 
the local microcontroller through its READY sig- 
nal (Pin 38). This permits microcontrollers with 
a wait state input to operate the disk controller 
system bus without any loss of performance if 
the microcontroller can normally perform read or 
write accesses faster than the CL-SM331 
permits. The component powers up with the 
maximum number of wait states inserted into 
every microcontroller access. The 
microcontroller can then program either no wait 
States or the actual number of wait states 
required by the system microcontroller. 
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4.1.2 Microcontroller-to-Buffer Manager 
interface 


Microcontroller access to the contents of the 
RAM Data Buffer and the Buffer Memory Data 
Bus are made accessible through the CL- 
SM331 Microcontroller Interface. The local 
microcontroller can read or write the contents of 
the RAM Data Buffer by means of a scheduled 
Buffer Memory access using the CL-SM331 Port 
50H (the Scheduled Buffer Data Register). The 
memory cycle access is considered scheduled 
because it is granted based on a rotating priority 
by the Buffer Manager regardless of whether it is 
a read or write memory request. The Disk 
Address Pointer (Registers 57H-59H) is used as 
the pointer into the Buffer Memory for all of the 
microcontroller accesses. Consequently, all 
disk operations must be terminated before the 
local microcontroller attempts any access to the 
RAM Data Buffer. 


In order to write a byte to the Buffer Memory, the 
microcontroller loads the CL-SM331 Port 50H 
(the Scheduled Buffer Data Register) with the 
data to be written to the Buffer Memory. This 
generates a transfer request to the Buffer 
Manager which will grant a prioritized Buffer 
Memory access cycle. When the byte has been 
successfully written, the Byte Ready Bit (Register 
79H, Bit 7) will be set. reading a byte from the 
Buffer Memory is initiated by having the micro- 
controller read Port 50H (the Scheduled Buffer 
Data Register). This first byte is discarded 
because it is a dummy read. When the status for 
byte ready becomes valid (the Byte Ready Bit 
(Register 79H, Bit 7) is set), then the first valid 
byte which is the byte pointed to by the Disk 
Address Pointer (Registers 57H-59H) has been 
read into Port 50H (the Scheduled Buffer Data 
Register). When that byte is read, the read 
strobe causes an automatic request for another 
Buffer Memory access cycle. This request 
causes the byte located at the next address 
pointed to by the Disk Address Pointer 
(Registers 57H-59H) to be fetched. Note that 
the Disk Address Pointer (Registers 57H-59H) is 
automatically increment after each access. 


Switches or jumpers for user configurable 
options can be implemented on the Buffer 
Memory Data Bus. The logical value of these 
switches is read in much the same way as a 
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byte of data is read from the Buffer Memory. 
However, the Memory Output Enable Signal 
(MOE* - Pin 16) should be disabled for both 
SRAM and DRAM Modes, and the BA16/RAS* 
(Pin 14) and the BA17/CAS* (Pin 15) signals 
should be disabled in DRAM Mode to prevent 
the Buffer Memory from driving the bus. The 
MOE* Signal (Pin 16), the BA16/RAS* Signal 
(Pin 14), and the BA17/CAS* Signal (Pin 15) 
can be disabled by setting the MOE Disable Bit 
(Register 53H, Bit 4). 


4.1.3 Microcontroller-to-SCSI Interface 


There are two methods that the local 
microcontroller can use to access the SCSI 
Data Bus: (1) transfers that are controlled 
completely by the firmware, or (2) Programmed 
I/O (PIO) transfers that use the CL-SM331 FIFO. 


In the first method, a single byte at a time is 
transferred and the transfer is handled 
completely by the firmware. Using firmware 
control to handshake and read or write each 
byte to the SCS! Data Bus is appropriate for 
particular SCS! Bus phases such as the 
Message In Phase or the Message Out Phase. 
This transfer method allows the microcontroller 
to monitor the SCSI Attention Signal (ATN* - Pin 
68) on a byte-by-byte basis (monitoring of the 
SCSI Attention Signal is a requirement of the 
SCSI-2 protocol during message transfers when 
a device is operating in Target Mode). 


For firmware controlled accesses, the 
information bytes are either read or written 
through the Direct SCSI Access Port (Register 
40H/60H). The SCSI Request Signal (REQ* - 
Pin 74) and the SCSI Acknowledge Signal 
(ACK* - Pin 68) are controlled and monitored in 
the SCSI Phase Control Register (42H/62H). 
The SCSI Phase is set in advance of the 
transfer in the SCSI Phase Control Register 
(42H/62H). 


In the second method, the CL-SM331 16-byte 
FIFO is used for automatic Programmed |/O 
(PIO) transfers. This permits automatic 
handshaking of the SCSI Request Signal (REQ* 
- Pin 74) and the SCSI Acknowledge Signal 
(ACK* - Pin 68) which allows up to 15 bytes of 
information to be transferred without any 
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microcontroller intervention. This method of 
transfer is useful for example in the SCSI 
Command Phase in order to bring in the first six 
bytes of a command. In fact, because most 
SCSI commands are six bytes long, this transfer 
method will bring in all of the command. 
Programmed 1/O (PIO) transfers can be 
asynchronous or synchronous. For example, 
asynchronous transfers would be used to 
transfer a command; whereas, synchronous 
transfers (if the negotiation is still valid) would 
be used to transfer the data requested by an 
Initiator. 


The microcontroller always accesses the CL- 
SM331 FIFO for reads or writes through the 
Microcontroller SCSI FIFO Access Port (Register 
4AH). The Programmed |/O (PIO) transfer count, 
control, and direction are all managed in the 
Buffer Transfer Control Register (52H). 


4.1.4 The CL-SM331 Local 
Microcontroller Interface 


Interrupts and status to the local microcontroller 
are consistently implemented from all four of the 
CL-SM331 functional blocks. The SCSI Host 
and the Buffer Manager interrupts are located in 
the SCSI Status Registers (46H/66H and 48H). 
The Sector Formatter interrupts are located in 
the Sector Formatter Interrupt Register (7DH). 


The SCSI Host and the Buffer Manager 
interrupts have their own dedicated interrupt 
signal output to the microcontroller via the CL- 
SM331 HINT Signal (Pin 33). The Sector 
Formatter interrupts also have their own 
dedicated interrupt signal output to the 
microcontroller via the CL-SM331 DINT Signal 
(Pin 32). This permits the microcontroller to 
localize the source of the interrupt or the 
pending status much quicker than if all of the 
interrupts were connected to the same interrupt 
output. If the local microcontroller permits only 
one interrupt signal then these interrupt sources 
collectively can be configured to drive only one 
interrupt output signal by setting the Local Int* 
Mode Enable Bit (Register 4FH, Bit 6). 


In addition each SCSI Host and Buffer Manager 
Status Bit can be masked individually via the 
SCSI Interrupt Enable Registers (47H/67H and 
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49H). Each Sector Formatter Status Bit can also 
be masked individually via the Sector Formatter 
Interrupt Enable Register (7EH). Because of this 
masking capability the bit can be prevented from 
generating an interrupt yet it still can provide 
status information to the microcontroller that is 
operating in polled mode. The interrupt output 
signals can be configured for open-drain 
operation in a multiplexed interrupt system by 
setting the Local Int Pin Pull-Up Disable Bit 
(Register 4FH, Bit 3). Interrupts can be disabled 
completely by resetting the interrupt enables. 
Interrupts are enabled by setting the Local HINT 
Enable Bit and the Local DINT Enable Bit (Bits 1 
and 2, respectively, of the Sector Formatter 
Mode Control Register (4FH)). Interrupts are 
disabled by resetting Bits 1 and 2 of Register 
4FH. 


4.2 SCSI Functional Description 


The second functional logic block of the CL- 
SM331 is the CL-SM331 Small Computer 
System Interface (SCSI). The control, timing, 
interface, and data transfer sections of this 
interface adhere to the requirements of the 
SCSI-2 proposed specification as well as to the 
ANSI X3.131-1986 SCSI specification. It is 
assumed that the reader is familiar with these 
requirements; otherwise, it is assumed that the 
ANSI document will be used in conjunction with 
Section 4.2. 


The SCSI Interface is the means of 
communication between a host computer 
system and one or more peripheral devices. A 
SCSI device assumes one of two roles in any 
SCSI Bus communication. The Initiator is 
defined as the SCSI device that generates a 
process, or more specifically the nexus. The 
Target is the recipient of the Initiator request and 
must execute some operation in response to an 
Initiator request. 


The SCSI Bus is an intermediate physical 
construct between the host system and the 
attached peripheral device(s). The host system 
uses an interface circuit to gain access to the 
SCSI Bus. Previously, the peripheral device 
usually required external interface circuitry to 
connect to the SCSI Bus. In the case of the CL- 
SM331, however, all of the required interface, 
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timing, control, and data paths are included in 
one integrated circuit. — 


The majority of the activity on the SCSI Bus is 
with the host system computer acting as an Ini- 
tiator that issues commands to a Target device 
such as a disk controller. It is through a well- 
defined protocol that the Initiator can request 
data reads or writes and other more 
sophisticated operations of the Target. It is 
permissible for a Target to assume the role of an 
Initiator and vice versa. 


4.2.1 Overview of the CL-SM331 SCSI 
Capabilities 


Implementation of the SCSI Bus Phases can be 
cumbersome. Consequently, many of these 
often-repeated processes are designed into the 
CL-SM331 control logic. Such routine SCSI 
Bus control operations as arbitration, selection 
and reselection are automatically sequenced in 
the CL-SM331 hardware; this results in more 
automated handling and ease of use. 


Program a SCSI ID for the device into Bits 2-0 of 
the SCSI Mode Control Register (44H/64H). 
The CL-SM331 can be programmed to assume 
either the role of an Initiator or a Target. For 
firmware-controlled operations the selection of a 
Target or Initiator is controlled by setting either 
the Enable Target Bit or the Enable Initiator Bit 
(Bits 4 and 5, respectively, in Register 45H/65H). 
Otherwise, the Target or Initiator role is derived 
from the programmed automatic operation (e.g., 
the selection, reselection, selection detected, or 
reselection detected process). 


The SCSI Bus signals can be programmed as 
open drain or active pull-up by setting the SCSI 
Active Pull-Up Select Bit (Register 45H/65H, Bit 
6) to the proper value. 


4.2.2 Microcontroller-to-SCSI Bus | 
Connection 


The local microcontroller is allowed access to 
the SCSI Data Bus through two distinct CL- 
SM331 address ports — (1) Port 40H/60H (the 
Direct SCSI Access Port Register), and (2) Port 
4AH (the Microcontroller SCSI FIFO Access Port 
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Register). The accesses can be handled singly 
under direct firmware control or by an automatic 
Programmed 1/O (PIO) circuit in the event of 
multiple bytes. In the latter case, the data is 
stored or received in the CL-SM331 16-byte 
FIFO. 


The local microcontroller is provided access to 
the SCSI Bus through addressing Port 40H/60H 
(the Direct SCSI Access Port Register). The 
microcontroller can either read or write data 
directly to the SCSI Bus through this port. The 
16-byte FIFO is given a separate port address 
so that the hardware can automatically 
distinguish the type of microcontroller to SCSI 
Bus access. The FIFO must be addressed by 
writing or reading Port 4AH (the Microcontroller 
SCSI FIFO Access Port Register). The FIFO can 
be used for stacking messages, sense data, or 
any other concurrent information transfer that 
would not constitute a DMA Data transfer. The 
direction of the information transfer is controlled 
by the SCSI R/W* Transfer Direction Bit 
(Register 52H, Bit 3). This applies to both DMA 
transfers (refer to the section on the SCSI Data 
transfers, Section 4.2.5) as well as automatic 
Programmed |/O (PIO) transfers through the 
FIFO. 


For the Programmed I/O (PIO) Mode of 
operation the REQ*/ACK* handshake is handled 
automatically by an internal CL-SM331 state 
machine. In the case of reading information 
from the bus, the expected or minimum number 
of bytes to be read should be loaded into the 
PIO Transfer Count Field (Register 52H, Bits 7- 
4). In the case of writing bytes to the SCSI Bus, 
the exact number of bytes to be written is always 
known so that the number of bytes for the Pro- 
grammed |/O (PIO) transfer should be loaded 
into the PIO Transfer Count Field (Register 52H, 
Bits 7-4). 


Before commencing with any new operation that 
will use the FIFO, the FIFO must be cleared by 
setting the Clear FIFO Bit (Bit 4) and then 
resetting this bit of the Buffer Status/Control 
Register (51H). The sequence is then started by 
setting the PIO Start Bit (Bit 2) of the Buffer 
Transfer Control Register (52H). The byte count 
in the FIFO can be obtained by reading the 
count in Bits 7-4 of Register 52H. The PIO Start 
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Bit (Register 52H, Bit 2) is automatically reset 
when the FIFO count has reached zero. 


Programmed |/O (PIO) transfers can be either 
asynchronous or synchronous. If the 
information being transferred is data and a 
previous synchronous negotiation is still in effect 
then the Programmed 1/O (PIO) transfer should 
be configured for synchronous transfers (refer to 
the section on SCSI Data transfers, Section 
4.2.5). 


4.2.3 SCSI Phase Control 


The majority of the SCSI Phase control and 
detection can be handled under the hardware 
control of the CL-SM331 if the CL-SM331 is 
programmed accordingly. The SCSI Arbitration 
Phase is automatically started by setting the 
Arbitration/Selection Start Bit (Register 45H/ 
65H, Bit 0). After waiting the appropriate Bus 
Free delay, the CL-SM331 ID Bit driven onto the 
SCSI Bus during the SCSI Arbitration Phase is 
derived from the encoded Bits 2-0 of the SCSI 
Mode Control Register (44H/64H). Arbitration 
has been won when the Arbitration/Selection 
Start Bit (Register 45H/65H, Bit 0) resets itself or 
the Arbitration Won Bit (Register 48H, Bit 2) is 
set. If arbitration was lost, the CL-SM331 
continues to arbitrate for control of the SCSI Bus 
until arbitration has been won, or until the 
Arbitration/Selection Start Bit (Register 
45H/65H, Bit 0) is reset by the local 
microcontroller. 


Whether the SCSI Selection Phase or the SCSI 
Reselection Phase is the pending phase (one or 
the other is the only possible phase after the 
SCSI Arbitration Phase) both the CL-SM331 ID 
and the desired Target or Initiator ID Bit must be 
set by writing to the Selection/Reselection ID 
Output Register (41H/61H). 


The SCSI Selection or Reselection phases are 
allowed to start automatically after a successful 
SCSI Arbitration Phase by setting the SCSI 
Automatic Selection/Reselection Enable Bit 
(Register 45H/65H, Bit 1). For the SCSI 
Selection Phase the SCSI Automatic 
Selection/Reselection Mode Bit (Register 
45H/65H, Bit 2) must be set. To go to the SCSI 
Reselection Phase the SCSI Automatic 
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Selection/Reselection Mode Bit (Register 
45H/65H, Bit 2) must be reset. 


If the device is an Initiator, then the SCSI 
Selection Phase is the appropriate SCSI Bus 
Phase to follow arbitration. The SCSI Attention 
Bit (Bit 6) of the SCS! Phase Control Register 
(42H/62H) should be set such that the SCSI 
Attention Signal (Pin 66) is automatically 
asserted low during the SCSI Selection Phase. 
This should be done before setting the SCSI 
Automatic Selection/Reselection Enable Bit 
(Register 45H/65H, Bit 1). Having set the SCSI 
Automatic Selection/Reselection Enable Bit (Bit 
1) of the SCSI Operation Control Register 
(45H/65H), the CL-SM331 will then proceed to 
the SCSI Selection Phase. 


If the device is a Target, then the SCSI 
Reselection Phase is the next phase to follow 
arbitration. The SCSI Input/Output* Bit (Bit 1) of 
the SCSI Phase Control Register (42H/62H) 
should be set such that the SCSI Input/Output 
Signal (Pin 75) is automatically asserted low 
during the SCSI Reselection Phase. This 
should be done before setting the SCSI 
Automatic Selection/Reselection Enable Bit 
(Register 45H/65H, Bit 1). Having set the SCSI 
Automatic Selection/Reselection Enable Bit (Bit 
1) of the SCSI Operation Control Register 
(45H/65H), the CL-SM331 will then proceed to 
the SCSI Reselection Phase. 


The CL-SM331 will also perform the converse of 
these functions automatically if the SCSI 
Automatic Selection/Reselection Enable Bit 
(Register 45H/65H, Bit 1) is set. That is, if the 
CL-SM331 is being selected by an Initiator, it 
will detect that it is being selected and will set 
the Device Selected Bit (Bit 0) in the SCSI 
Status Register 2 (48H). In addition, the CL- 
SM331 will respond to the selection by: (1) 
setting the Enable Target Bit (Bit 4) of the SCSI 
Operation Control Register (45H/65H), (2) 
asserting low the SCSI Busy Signal (Pin 67), (3) 
setting the SCSI Busy Bit (Bit 4) of the SCSI 
Phase Control Register (42H/62H), and (4) 
latching the contents of the SCSI Data Bus into 
the Selection/ Reselection ID Input Register 
(41H/61H). 
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If a valid reselection by a Target is observed on 
the bus, the CL-SM331 will set the Device 
Reselected Bit (Bit 1) of the SCSI Status 
Register 2 (48H). The CL-SM331 will also do 
the following: (1) set the Enable Initiator Bit 
(Register 45H/65H, Bit 5), (2) assert the SCSI 
Busy Signal (Pin 67) low and set the SCSI Busy 
Bit (Bit 4) of the SCSI Phase Control Register 
(42H/62H) until the SCSI Select Signal (Pin 72) 
is asserted low, and (3) latch the contents of the 
SCSI Data Bus into the Selection/ Reselection 
ID Input Register (41H/61H). 


If the control of the SCSI Selection or 
Reselection Phase is performed through 
firmware operations then the SCSI control 
signals are qualified with one of two bits — the 
Enable Target Bit or the Enable Initiator Bit (Bits 
4 and 5, respectively, of Register 45H/65H). 


The Enable Target Bit (Register 45H/65H, Bit 4) 
is set to allow the CL-SM331 to drive the 
following Target signals: the SCSI Message 
Signal (Pin 70), the SCSI Command /Data 
Signal (Pin 73), the SCSI Input/Output Signal 
(Pin 75), and the SCSI Request Signal (Pin 74). 
These signals can be individually controlled or 
monitored in the SCSI Phase Control Register 
(42H/62H). 


The Enable Initiator Bit (Register 45H/65H, Bit 5) 
is set to allow the CL-SM331 to drive the 
following Initiator signals: the SCSI Attention 
Signal (Pin 66) and the SCSI Acknowledge 
Signal (Pin 68). These two signals can be 
controlled or monitored through the SCSI Phase 
Control Register (42H/62H). 
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The SCSI Busy Signal (Pin 67) and the SCSI! 
Select Signal (Pin 72) that are controlled by Bits 
4 and 5 of Register 42H/62H are not gated by 
either the Enable Target Bit or the Enable 
Initiator Bit (Bits 4 and 5, respectively, of 
Register 45H/65H). The SCSI Select Signal 
(Pin 72) can be driven to allow for a firmware- . 
controlled SCSI Selection Phase in Initiator 
Mode or a SCSI Reselection Phase in Target 
Mode. This also permits the SCSI Busy Signal 
(Pin 69) to be asserted low by the firmware in 
response to being selected or reselected yet still 
allows the CL-SM331 to assert this signal for 
automatic arbitration. 


Because the SCS/ Data Bus must be driven with 
the Initiator and Target ID values during the 
SCSI Selection and Reselection phases the 
Microcontroller Direct SCS! Output Enable Bit 
(Register 45H/65H, Bit 3) must be set before 
setting the Enable Target Bit or the Enable 
Initiator Bit (Bits 4 and 5, respectively, of 
Register 45H/65H). This allows the SCSI Data 
Bus to be driven provided that the Enable 
Initiator Bit or the Enable Target Bit is set during 
the selection or reselection process. 


The RST* Signal (Pin 19) has a more global 
effect on the function of the SCSI Bus and can 
be asserted low at anytime by setting the SCSI 
Reset Out Bit (Bit 7) of the SCSI Operation 
Control Register (45H/65H). 
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4.2.4 SCSI Information Transfer Phases 


All SCS! Bus phases other than the Arbitration, 
Selection, and Reselection phases are 
collectively defined as Information Transfer 
phases. The Information Transfer Phase is 
always set by the Target device during 
communication with an Initiator. The phase is 
defined by the encoded values of the following 
SCSI signals: the SCSI] Command/Data Signal 
(Pin 73), the SCSI Input/Output Signal (Pin 75), 
and the SCSI Message Signal (Pin 70). The 
Information Transfer Phase is set through 
firmware by the local microcontroller for the 
particular Target. The Enable Target Bit 
(Register 45H/65H, Bit 4) must be set either in 
firmware or through an automatic selection or 
selection detected process before these signals 
are actively driven by the CL-SM331. Note that 
the corresponding bits in the SCSI Phase 
Control Register (42H/62H) for the SCSI 
Command/Data Signal (Pin 73), the SCSI 
Input/Output Signal (Pin 75), and the SCSI 
Message Signal (Pin 70) are the logical 
complement of the levels on the bus because 
the SCSI Bus is an active low bus. 


Bit O of the SCSI Phase Control Register 
(42H/62H) is the SCS! Control/Data* Bit. When 
this bit is set, it indicates that the information 
being transferred on the SCSI Data Bus signals 
is either command, status, or message byte(s). 
Resetting this bit to a logical zero indicates that 
the information being transferred is data byte(s). 


Bit 1 of the SCS! Phase Control Register 
(42H/62H) is the SCSI Input/Output* Bit. This bit 
indicates the direction of information transfer 
with respect to the Initiator. When this bit is set 
to a logical one, the information will be 
transferred in to the Initiator. Resetting this bit to 
a logical zero indicates that the information will 
be transferred out from the Initiator to the Target. 


Bit 2 of the SCSI Phase Control Register 
(42H/62H) is the SCSI Message Bit. When this 
bit is set, it indicates that the information transfer 
is specifically a SCSI message. When this bit is 
reset, then the information could be data, a 
command, or status. A SCSI message could be 
either a Message In to the Initiator or a Message 
Out to the Target. 
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The following table lists the permissible 
Information Transfer phases for the encoded 
states of Bits 2-0 of the SCSI Phase Control 
Register (42H/62H). 


Information Transfer Phase Control Bits 
Register 42H/62H 


Bit 2 Bit O Bit 1 Information 

MSG C/D* 1/O* Transfer Phase 

0 0 0 Data Out Phase 

0 0 1 Data In Phase 

0 1 ) Command Out Phase 
0 1 1 Status In Phase 

1 0 0 Undefined 

1 0 1 Undefined 

1 1 0 Message Out Phase 
1 1 1 Message In Phase 


As a Target, the CL-SM331 can go to a SCSI 
Message In phase at any time by setting the 
three bit values as shown in the table above. As 
an Initiator, however, the CL-SM331 has no 
control over these three bits. As an Initiator to 
request a SCSI Message Out Phase, the local 
microcontroller should set the SCSI Attention Bit 
(Bit 6) of the SCSI Phase Control Register 
(42H/62H). The Target device should respond 
by setting the phase to a SCSI Message Out 
Phase at the earliest possible time. 


These three Information Transfer Phase Control 
bits can also be used by the Initiator to read their 
value if required. They will provide status to the 
Initiator if the Target changes one or more of 
their values to an Information Transfer Phase 
that the Initiator is not expecting. 


In the execution of most SCSI nexus, the 
Initiator can predict the next phase of operation. 


. For example from the SCSI Command Phase, 


depending on the command, the Target will 
typically enter a SCSI Status Phase or Data 
Phase. The Initiator can predict this from the 
command sent. When in Initiator Mode, the CL- 
SM331 provides a status signal or an interrupt if 
the Target device drives to a SCS! Bus Phase 
that the Initiator does not expect (e.g., the 
Message In Phase). A transfer will not occur to 
prevent erroneous information transfer. 
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Bits 2-0 of Register 42H/62H should be set by 
the Initiator Microcontroller to the predicted 
state. That is, the expected Information Transfer 
Phase should be encoded using the SCSI 
Message Bit, the SCSI Input/Output* Bit, and the 
SCSI Control/Data* Bit (Bits 2-0, respectively, of 
Register 42H/62H). On each falling (leading) 
edge of the SCSI Request Signal (Pin 74), the 
CL-SM331 compares the Target-Driven Phase 
against the predicted state programmed in the 
CL-SM331. If any one of the three signals differ 
from the bits pre-programmed by the Initiator 
then the SCSI Phase Mismatch Bit (Bit 6) of the 
SCSI Status Register 2 (48H) will be set. 


These bits can be read at anytime by either an 
Initiator or a Target. The values read always 
reflect the logical complement of the value on 
the CL-SM331 SCSI Bus Pin. 


4.2.5 SCSI Data Transfers 


SCSI Data is transferred either during a SCSI 
Data In or Data Out Phase. This is done either 
by an Initiator or a Target with the Target device 
controlling the data transfer. The major features 
in the CL-SM331 to improve data integrity, ease 
of implementation, and performance include the 
following: odd parity generation and detection, a 
16-byte FIFO, an automatic DMA Transfer Mode, 
and both asynchronous and synchronous data 
transfers with the option of either a single-ended 
or differential bus connection. 


SCSI parity checking is enabled by setting the 
SCSI Parity Enable Bit (Register 44H/64H, Bit 
3). Parity generation is not affected by the value 
of the SCSI Parity Enable Bit (Register 
44H/64H, Bit 3). If a parity error is detected 
during a data transfer then the SCSI Bus Parity 
Error Detected Bit (Bit 5) of the SCSI Status 
Register 1 (46H/66H) is set. A parity error can 
only be detected on the SCSI Bus when data is 
being read from the other device whether it is a 
Target or Initiator. 


In addition to SCSI Bus parity, there is a parity 
circuit between the internal CL-SM331 SCSI 
Bus and the RAM Data Buffer Port. This parity 
detection circuitry is enabled if the Buffer 
Memory Parity Enable Bit (Bit 3) of the Buffer 
Mode Control Register (53H) is set. This 
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ensures the integrity of the data being read from 
the RAM Data Buffer to the CL-SM331 SCSI 
Interface logic. If a parity error is detected, it is 
latched in the SCSI/Buffer Parity Error Detected 
Bit (Bit 4) of the SCSI Status Register 1 
(46H/66H). 


Internal to the CL-SM331 and transparent to the 
user is a 16 byte bidirectional FIFO used in data 
reads or writes with the RAM Data Buffer. This 
FIFO acts as a buffer between the host (SCSI) 
transfer rate and the rate at which data is written 
to or read from the Buffer Memory. The FIFO is 
useful for preventing overruns or underruns as 
its status is used to control the assertion low of 
the SCSI Request Signal (Pin 74) as a Target or 
the assertion low of the SCSI Acknowledge 
Signal (Pin 68) as an Initiator. 


The transfer of data is under the control of an 
automatic state sequencer which allows for the 
ability of a high-speed, DMA transfer to or from 
the RAM Data Buffer. DMA Data transfers are 
enabled by setting the DMA Start Bit (Bit 1) in 
the Buffer Transfer Control Register (52H). This 
bit is reset at the completion of a DMA transfer. 
A DMA transfer that is in progress can be 
cleanly terminated by resetting the DMA Start Bit 
(Register 52H, Bit 1). 


The CL-SM331 is capable of asynchronous 
data transfers up to 3 Mbytes/second, and 
synchronous data transfers up to 5 
Mbytes/second Synchronous transfers are 
established through a defined message 
protocol. The two parameters that must be 
agreed upon between the Initiator and Target 
are an offset count and a synchronous transfer 
period. It is incumbent on the _ local 
microcontroller to arrive at compatible 
parameters with the other SCSI device. The 
parameters can then be programmed into the 
SCSI Synchronous Control Register (43H/63H). 
The offset count can be loaded with values from 
1-15 bytes by setting the appropriate values into 
Bits 3-0 of Register 43H/63H. An offset of zero 
sets data transfers to the asynchronous mode of 
operation. The synchronous transfer period is a 
function of the input SYSCLK frequency and 
can assume 12 different periods depending on 
the values programmed in Bits 7-4 of Register 
43H/63H. 
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4.2.6 Differential SCSI 


Six additional pins are provided with the CL- 
SM331 for the control of the external logic that is 
necessary to implement the Differential Mode of 
bus operation. The Differential Mode is always 
enabled such that the six control pins always 
drive the correct control and timing. If 
Differential Mode is designed then the pins are 
connected controlling the external logic; 
otherwise, the outputs are left unconnected. 
There are no internal control bits in the CL- 
SM331 to differentiate between the Single- 
ended and the Differential Mode of operation. 


4.3 Buffer Manager Interface 


The third functional logic block of the CL-SM331 
is the Buffer Manager Interface. This block 
controls the flow of data between the external 
RAM Data Buffer and the CL-SM331 SCSI 
Interface, the Sector Formatter Data path, and 
the Microcontroller Buffer Memory access ports. 
The Buffer Manager Interface provides the 
external RAM addressing, timing, and control 
signals necessary for the CL-SM331 to interface 
with the RAM Data Buffer. The Buffer Manager 
Interface also provides an additional data bit 
signal called the Buffer Memory Data Parity 
Signal (BDP - Pin 95) for odd parity generation 
and checking. 


The Buffer Manager logic can control either a 
Static RAM (SRAM) Buffer or Dynamic RAM 
(DRAM) Buffer. The CL-SM331 powers up in 
the SRAM Mode. If DRAM Operation is desired 
then the DRAM/SRAM* Bit (Register 53H, Bit 0) 
should be set. The topics that are common to 
these two modes of operation are discussed in 
Sections 4.3.1 - 4.3.2. The two modes of 
operation, however, are sufficiently different that 
most of the logic is described in two different 
sections depending on the configuration. For 
details on the SRAM Buffer Interface Operation 
refer to Section 4.3.3. For details on the DRAM 
Buffer Interface Operation refer to Section 4.3.4. 
For details on hardware ECC Vector 
Processing, refer to Section 4.3.5. 
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4.3.1 RAM Data Buffer Segmentation 


For optimum data flow control it is often 
desirable to divide the Buffer Memory into 
smaller ‘protected’ segments. The Buffer 
Manager provides the option to configure the 
RAM Data Buffer into 64K bytes data segments 
on 64K bytes address boundaries. The data 
segment is designated by the two or four most 
significant RAM address bits. 


This Buffer Segmentation Mode is enabled by 
setting the Enable Buffer Segmentation Bit 
(Register 52H, Bit 0). In this mode after a Buffer 
Memory transfer is completed, only the address 
pointer lower and middle bytes are incremented. 
Consequently, the lower and middle bytes of the 
address pointers would roll over to OOOOH 
without any change to the address pointer upper 
two bits which designate the segment. 


4.3.2 RAM Data Buffer Parity 


The CL-SM331 supports data parity on the 
external RAM Data Buffer. The Buffer Manager 
interface can be configured to generate the odd 
parity of the 8-bit data being written to the RAM 
Buffer. This parity check bit is written along with 
the 8-bit data to a 9-bit wide RAM Data Buffer. 
The Buffer Memory Data Parity Signal (Pin 95) 
is connected to the additional RAM device(s). 


If the data is sourced from the Sector Formatter 
Data path, then the odd parity is generated at 
the serializer/deserializer (SERDES) and is 
passed through to the Buffer Memory Data 
Parity Signal (Pin 95). If the data is sourced 
from the SCSI Host Interface then the parity 
generation is dependent on the value of the 
SCSI Parity Enable Bit (Bit 3) of the SCSI Buffer 
Control Register (44H/64H). If this bit is set then 
the value of the parity received from the SCS! 
Data Bus is passed through to the Buffer 
Memory Data Parity Signal (Pin 95). If this bit is 
reset then the odd parity value of the data 
received from the SCSI Data Bus is generated 
inside the CL-SM331, and then is written out on 
the Buffer Memory Data Parity Signal (Pin 95). 


When data is being read from the RAM Data 
Buffer, the odd parity value can be tested or 
ignored. If the Buffer Memory Parity Enable Bit 
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(Bit 3) of the Buffer Mode Control Register (53H) 
is set, then the bit value received from the Buffer 
Memory Data Parity Signal (Pin 95) is tested. It 
is tested to see if it is the odd parity value of the 
eight bits on the Buffer Memory Data Bus 
signals (BDO-7). The data being read from the 
RAM Data Buffer is either for the SCSI Host 
Interface or the SERDES of the Sector Formatter 
Data path. In both cases there is a bit available 
to report a parity error if one is detected by the 
CL-SM331 parity checking circuitry. 


lf the Sector Formatter is reading the RAM Data 
Buffer and a parity error is detected on the Buffer 
Memory Data Parity Signal (Pin 95), then the 
Disk/Buffer Parity Error Bit (Bit 6) of the Format 
Sequencer Status Register 2 (7AH) is set. If the 
SCSI Host Interface is reading from the RAM 
Data Buffer and a parity error is detected, then 
the SCSI/Buffer Parity Error Detected Bit (Bit 4) 
of the SCSI Status Register 1 (46H/66H) is set. 
The subsequent actions are firmware 
dependent; this enables different responses to 
the RAM Data Buffer parity errors to be 
constructed in the program. 


If the Buffer Memory Parity Enable Bit (Bit 3) of 
the Buffer Mode Control Register (53H) is reset 
then the two status bits — the Disk/Buffer Parity 
Error Bit (Register 7AH, Bit 6), and the 
SCS|/Buffer Parity Error Detected Bit (Register 
46H/66H, Bit 4) are always reset. 


4.3.3 SRAM Buffer Interface Operation 


In order to ensure the proper operation of the 
Buffer Manager in SRAM Mode, the 
DRAM/SRAM* Bit (Bit 0) of the Buffer Mode 
Control Register (53H) and the DRAM Burst 
Enable Bit (Bit 6) of the Buffer Status/Control 
Register (51H) must be reset. 


4.3.3.1 SRAM Addressing Operation 


When in the SRAM Mode of operation, the 
Buffer Manager Interface can address up to 
256K bytes of memory. This requires 18 
address lines that correspond to the Buffer 
Manager Address signals BAQO-17 (Pins 96-99, 
1-8, and 10-15). The Buffer Memory Address is 
never placed in a high-impedance state; it is 
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always driven by one of two sources — the Disk 
Address Pointer (Registers 57H-59H) or the 
Host Address Pointer (Registers 5AH-5CH). 
These pointers have various initialization 
conditions and their starting values can be 
changed via direct firmware control. 


The Disk Address Pointer (Registers 57H-59H) 
is dedicated for disk and microcontroller 
transfers. The two high-order bits of the Disk 
Address Pointer (Registers 57H-59H) are in Bits 
1-0 of Register 59H. The middle-order eight bits 
are in Register 58H, and the low-order eight bits 
are in Register 57H. Any access to the RAM 
Data Buffer by the Sector Formatter selects the 
value in Registers 57H-59H, the Disk Address 
Pointer, to be driven out on the Buffer Memory 
Address Bus. 


When the local microcontroller accesses the 
Buffer Memory, the Disk Address Pointer 
(Registers 57H-59H) is also used. 
Consequently, in order to prepare for a local 
microcontroller access to the Buffer Memory all 
disk transfers to or from the CL-SM331 must be 
terminated before the Disk Address Pointer 
(Registers 57H-59H) is loaded. 


The Host Address Pointer (Registers 5AH-5CH) 
is reserved for transfers between the SCSI Bus 
and the RAM Data Buffer. The Host Address 
Pointer two high-order bits are in Bits 1-0 of 
Register 5CH. The middle-order eight bits are in 
Register 5BH, and the low-order eight bits are in 
Register 5AH. Any access to the RAM Data 
Buffer by the SCSI Interface logic selects the 
value in Registers 5AH-5CH, the Host Address 
Pointer, and has the CL-SM331 drive this value 
onto the Buffer Memory Address Bus. 


The Host Address Pointer (Registers 5AH-5CH) 
is compared with the Stop Address Pointer 
(Registers 5DH-5FH) in order to contain the data 
transfers to a particular block boundary value. 
To translate the value of the Host Address 
Pointer (Registers 5AH-5CH) into a repeatable 
block size, the Buffer Size Register (56H) is 
used to mask the upper address bits of the Host 
Address Pointer (Registers 5AH-5CH) and the 
Stop Address Pointer (Registers 5DH-5FH). 
Consequently, only the lower significant bits that 
are module a block size are used for the 
comparison. When the comparison of the Host 
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Address Pointer (Registers 5AH-5CH) and the 
Stop Address Pointer (Register 5DH-5FH), 
masked by the Buffer Size Register (56H), is 
equal, then the host transfer is terminated. 


Both the Disk Address Pointer (Registers 5/H- 
59H) and the Host Address Pointer (Registers 
5AH-5CH) are automatically incremented by a 
count of one after the completion of each access 
to the RAM Data Buffer. 


lf Buffer Manager segmentation is disabled 
(refer to the section on Buffer Manager 
segmentation, Section 4.3.1), then all 18 buffer 
Memory Address lines (BAQO-17) are subject to 
being incremented after each RAM Data Buffer 
access. If the system static Buffer Memory is 
less than 256K bytes, then do not use the 
remaining most significant Buffer Memory 
Address lines as memory chip selects. This 
limitation is imposed because the incrementing 
of the high-order address lines will deselect the 
memory chip(s). The firmware may avoid this 
problem by managing the address pointers (the 
Disk Address Pointer (Registers 57H-59H) and 
the Host Address Pointer (Registers 5AH-5CH)) 
on the proper address block boundaries. 


4.3.3.2 SRAM Read/Write Access 
Control 


The Buffer Manager accesses the Buffer 
Memory Data Bus to read or to write the 
contents of the RAM Data Buffer, or to read the 
static state of the Data Bus (refer to Section 
4.1.2 for more details). The direction of the 
access must be specified in order to generate 
the correct control signals. The SCSI Host, the 
Sector Formatter, and the local microcontroller 
all use unique methods to specify the direction 
of the access. 


In the case of SCSI Host transfers, the 
read/write control is set by the SCSI R/W* 
Transfer Direction Bit (Bit 3) of the Buffer 
Transfer Control Register (52H). When this bit is 
set, the data read from the RAM Data Buffer is 
transferred through the CL-SM331 chip to the 
SCSI Host Interface. If this bit is reset then the 
data is transferred from the SCSI Host Interface 
through the CL-SM331 chip and written to the 
RAM Data Buffer. 


April 1991 


i 


===" CIRRUS LOGIC 


In the case of Sector Formatter transfers, the 
transfer direction is controlled by the Buffer/Disk 
R/W* Transfer Direction Bit (Bit 3) of the Sector 
Formatter Operation Control Register (77H). 
When this bit is set, the data read from the RAM 
Data Buffer is transferred to the Sector 
Formatter. In order to write to the RAM Data 
Buffer from the Sector Formatter this bit must be 
reset. 


In the case of microcontroller transfers, the 
microcontroller control strobe is used in order to 
determine the transfer direction. A read of the 
CL-SM331 Port 50H (the Scheduled Buffer Data 
Register) results in a read of the RAM Data 
Buffer. A write to Port 50H (the Scheduled 
Buffer Data Register) causes a write to the RAM 
Data Buffer. 


Given the direction of data transfer from the 
above controls, all read operations are the same 
regardless of the requesting source and 
similarly, all write operations are the same. Both 
the read and write operation commence when 
the correct address pointer (the Disk Address 
Pointer (Registers 57H-59H), or the Host 
Address Pointer (Registers 5AH-5CH)) is driven 
onto the Buffer Memory Address Bus. 


In the case of a read to the RAM Data Buffer, the 
Memory Output Enable Signal (MOE* - Pin 16) 
is asserted low after the address is driven onto 
the Address Bus. This signal should be con- 
nected to the SRAM Output enable(s) to ensure 
the highest throughput. Data must be provided 
from the SRAM shortly before the rising (trailing) 
edge of the Memory Output Enable Signal 
(MOE* - Pin 16). The duration of the Memory 
Output Enable Signal (MOE* - Pin 16) is a 
programmable parameter (refer to the section 
on SRAM Signal timing, Section 4.3.3.3). The 
Write Enable Signal (WE* - Pin 17) remains 
deasserted high throughout the entire SRAM 
access. 


In the case of a write to the RAM Data Buffer, the 
Memory Output Enable Signal (MOE* - Pin 16) 
and the Write Enable Signal (WE* - Pin 17) are 
concurrently asserted low after the address is 
driven onto the Address Bus. In order to ensure 
the highest throughput the Memory Output 
Enable Signal (MOE* - Pin 16) should be 
connected to the SRAM Output enable(s) and 
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the Write Enable Signal (WE* - Pin 17) should 
be connected to the SRAM write enable or 
read/write control pin. Data is driven from the 
CL-SM331 to the RAM Data Buffer shortly after 
the address is driven. The Memory Output 
Enable Signal (MOE* - Pin 16) and the Write 
Enable Signal (WE* - Pin 17) are deasserted 
high at the same time near the end of the cycle. 
The duration of the Memory Output Enable 
Signal (MOE* - Pin 16) and the Write Enable 
Signal (WE* - Pin 17) are a programmable 
parameter (refer to the following section on 
SRAM Signal timing, Section 4.3.3.3). 


4.3.3.3 SRAM Signal Timing 


For both a read and a write access to the RAM 
Data Buffer the correct address pointer (the Disk 
Address Pointer (Registers 57H-59H), and the 
Host Address Pointer (Registers 5AH-5CH)) is 
driven with respect to the rising edge of the 
SYSCLK Signal Input (Pin 24). For both read 
and write accesses the Memory Output Enable 
Signal (MOE* - Pin 16) is asserted low one-half 
SYSCLK after the address is driven. In the case 
of a write access, the Write Enable Signal (WE* 
- Pin 17) also starts being driven off of the falling 
edge of the SYSCLK Signal (Pin 24) one-half 
clock after the address is driven. 


The Memory Output Enable Signal (MOE”* - Pin 
16) and the Write Enable Signal (WE* - Pin 17) 
in the case of a write are both deasserted high 
one-half SYSCLK before the end of the SRAM 
access. This implies that the total SRAM access 
time controls the pulse width of these signals. 
The complete SRAM access time is 
programmed in terms of SYSCLK Input Signal 
(Pin 24) periods. By programming a value into 
Bits 1-0, RAS* Low Time/SRAM Cycle Time, of 
the Buffer Manager Timing Control Register 
(54H) an access time of 2T to 5T (where T is the 
SYSCLK Signal (Pin 41) period) can be 
obtained. 

The values of 2t, 3t, 4t, or 5t refer to the time from 
the rising edge of SYSCLK, that drives the 
address valid, to the rising edge of SYSCLK 
following the release of the Memory Output 
Enable Signal (MOE* - Pin 16) and the Write 
Enable Signal (WE* - Pin 17) one-half clock 
earlier. This yields a Memory Output Enable 
and Write Enable pulse width of approximately 
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one period less than the value programmed. 
The address is held one-half clock after the 
release of the Memory Output Enable (MOE”* - 
Pin 16) and the Write Enable (WE* - Pin 17) 
signals. 


In the case of a read access to the RAM Data 
Buffer, data is clocked into the CL-SM331 on the 
same falling edge of SYSCLK that causes the 
release of the Memory Output Enable Signal 
(MOE* - Pin 16). In the case of a write, data is 
held by the CL-SM331 until the same rising 
edge of SYSCLK, which removes the address. 
The Write Enable Signal (WE* - Pin 17) is 
released one-half clock earlier to write the data 
to the RAM Data Buffer. 


The Buffer Memory Data Parity Signal (Pin 95) 
has the same timing output and input 
requirements as all of the Buffer Memory Data 
Bus signals (BDO-7). 


In SRAM Mode, the theoretical maximum Buffer 
Manager throughput is 12 Mbytes/second. The 
actual throughput is a function of the NRZ clock 
frequency from the disk drive, the SRAM speed 
used or required, the desired host throughput, 
and the input SYSCLK Signal (Pin 24) 
frequency. In general, the actual SRAM 
throughput available can be derived from the 
SRAM access time programmed in Bits 1-0 of 
Register 54H. The total Buffer Manager 
throughput that is available can be obtained by 
multiplying the SYSCLK period times the 
number of cycles programmed; the throughput is 
the inverse of this value. 


4.3.4 DRAM Buffer Interface Operation 


When the CL-SM331 is operating in DRAM 
Mode, the Buffer Manager Interface can address 
up to 4 MByte of memory. Before programming 
the CL-SM331 for DRAM Operation, the refresh 
period, the DRAM device organization, and the 
DRAM timing parameters must be programmed. 
The CL-SM331 is configured for DRAM 
Operation by setting the DRAM/SRAM* Bit (Bit 0) 
of the Buffer Mode Control Register (53H). 
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4.3.4.1 DRAM Parameter Programming 


The refresh period is programmed in the DRAM 
Refresh Period Register (55H). This is an eight- 
bit value that is appended to a ninth (least 
significant value) bit which is always preset to 
one. This refresh period multiplied by the 
SYSCLK Input period sets the time interval 
between automatic Refresh operations. 


The CL-SM331 supports a read Address Strobe 
(RAS) — only refresh scheme. This scheme is 
supported with an on-board, nine-bit refresh 
counter. This counter is referred to as the 
Refresh Address Counter and holds the Buffer 
Memory row address that is to be refreshed. It is 
incremented after a memory refresh cycle. This 
counter is initialized to zero when the RST* 
Signal (Pin 19) is asserted low. 


The Buffer Manager Timing Control Register 
(54H) contains the following four fields - CAS* 
High Time (Bits 7-6), CAS* Low Time (Bits 5-4), 
RAS* High Time (Bits 3-2), and RAS* Low Time 
(Bits 1-0). These four fields must be 
programmed with the _ specific timing 
characteristics of the DRAM devices used. Each 
of these four fields is allocated two bits. This 
enables each of the four DRAM timing 
characteristics to be programmed with one of 
four values. The values are integral multiples of 
the SYSCLK Input Signal (Pin 41) period. 
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The parameters that need to be programmed 
into these four fields are as follows: (1) the 
BA17/ CAS* Signal (Pin 15) high time for a 
DRAM Page Mode access, (2) the BA17/CAS* 
Signal (Pin 15) low time for a DRAM Page Mode 
Access, (3) the BA16/RAS* Signal (Pin 14) high 
or precharge time, and (4) the BA16/RAS* 
Signal (Pin 14) low time during a normal DRAM 
access. Refer to the section on the BA16/RAS* 
and BA17/CAS* Signal timing, Section 4.3.4.4, 
for more details on these parameters. 


To ensure that the Buffer Manager drives the 
row and column address bits on the correct 
signal lines without any multiplexing or other 
external logic being required, the device 
Organization should be programmed into the 
DRAM Type Field (Register 53H, Bits 2-1). The 
following four DRAM types are supported 64K 
bits, 256K bits by 1 bit or 4 bits, 1 Mbit and 4 
Mbit devices. 
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4.3.4.2 DRAM Addressing Operation 


The CL-SM331 supports 64K bytes, 256K bytes, 1 Mbytes, and 4 Mbytes DRAMs, and provides up to 
4 Mbytes of address space. The following table shows how the bits from the address pointer (either 
the Disk Address Pointer Registers 5/H-59H, or the Host Address Pointer Registers 5AH-5CH) map 
into the Buffer Memory Address lines BAQ-10 (Pins 96-99, 1-7) for each DRAM size during row and 
column address time: | 


MEMORY SIZE BUFFER ADDRESS LINES 
10 9 8 7 6 5 4 3 2 1 0 
64K DRAM ROW ADDRESS 18 17 #16 15 14 13 12 11 10 9 8 
COLUMN ADDRESS 10 9 8 7 6 5 4 3 2 1 0 
256K DRAM ROW ADDRESS 19 18 17 16 15 14s 18 12 11 10 «#9 
COLUMN ADDRESS 10 9 8 Ud 6 5 4 3 2 1 0 
1M DRAM ROW ADDRESS 20 19 18 17 16 15 14 13 12 11 10 
COLUMN ADDRESS 10 9 8 7 6 5 4 3 2 1 0 
4M DRAM ROW ADDRESS 21 20 838619 18 17 16 »=15 14 13 12 11 
COLUMN ADDRESS 10 9 8 7 6 5 4 3 2 1 0 


During a refresh operation the 11-bit Refresh Address Counter is driven on the Buffer Memory 
Address lines BAO-10 (Pins 96-99, 1-7). Unlike SRAM Mode, for DRAM Operation the most significant 
bits of the Buffer Memory Address are constant for 64K bit, 256K bit and 1 Mbit devices. These upper 
bits are managed by the firmware and force an inherent buffer segmentation equal to the RAM device 
size. In the case of a 4 Mbit device, all of the Buffer Memory Address bits (Bits 21-0) can be 
incremented. 


The concept of the Buffer Size Register (56H) masking the comparison of the high-order bits between 
the Host Address Pointer (Registers 5AH-5CH), and the Stop Address Pointer (Registers 5DH-5FH) is 
the same as described for the SRAM Mode of operation (refer to Section 4.3.3.1). The value in the 
Buffer Size Register (56H) determines the number of high-order address bits to mask in the 
comparison between the Host Address Pointer (Registers 5AH-5CH) and the Stop Address Pointer 
(Registers 5DH-5FH). The result of this comparison is used by the Buffer Manager to decide when to 
terminate the current Buffer Memory transfer. Bits are masked starting from the most significant row 
address bits until the request segment size is reached. 
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4.3.4.3 DRAM Page and Burst Mode 
Operation 


The Buffer Manager always accesses the DRAM 
in Page Mode. This mode allows multiple byte 
accesses for each assertion of the BA16/RAS* 
Signal (Pin 14). To operate DRAM in Page 
Mode the Buffer Manager first asserts the 
BA16/RAS* Signal (Pin 14) followed by multiple 
CAS* cycles to strobe each new byte. This is the 
reason the CAS* timing programmed into 
Register 54H is the Page Mode CAS* timing 
rather than the single access timing. As 
mentioned previously, Refresh operations are 
Read Address Strobe (RAS) — only and are not 
considered Page Mode accesses. 


When in DRAM Mode, the SCSI Host requests 
and the Sector Formatter requests for a Buffer 
Memory access are all Page Mode accesses in 
one of two forms. Setting the DRAM Burst 
Enable Bit (Bit 6) of the Buffer Status/Control 
Register (51H) forces the Buffer Manager into a 
memory access when four bytes are ready for 
transfer. This mode of operation assures the 
most efficient use of the DRAM devices because 
it uses them in their fastest access mode. 


If the Host Interface has a byte ready for transfer 
to the RAM Data Buffer the Buffer Manager will 
not grant memory access cycles for the data in 
the host FIFO until there are at least four bytes 
ready for transfer. The same applies to the 
Sector Formatter Interface to the Buffer Manager. 
The Sector Formatter has an internal FIFO used 
to stack data that is to be read from or written to 
the RAM Data Buffer. The length of the data 
burst may be less than four bytes when the 
Buffer Manager is transferring the last or 
remaining data bytes of the requested transfer. 
Because DRAMs require a new RAS* cycle at 
each page break of the column address the 
Buffer Manager must stop a burst transfer on a 
page boundary and this could also result in a 
data burst of less than four bytes. 


lf the DRAM Burst Enable Bit (Register 51H, Bit 
6) is reset then the Buffer Manager operates ina 
demand mode. In this mode, the Buffer Manager 
transfers up to four bytes to or from an interface. 
That is, if the SCSI Host Interface has only one 
byte in the internal FIFO or one byte available 
then that byte is transferred to or from the RAM 
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Data Buffer. In the interim due to requests from 
the Sector Formatter and/or a Refresh Operation, 
three bytes have been either filled or emptied 
from the host FIFO. The request is then 
recognized and granted. After the request is 
granted, three bytes are transferred to or from the 
RAM Data Buffer. Requests are granted in a 
rotating priority with the request for a Refresh 
Operation always’ taking precedence. 
Consequently, the Sector Formatter FIFO can 
give or receive up to four bytes and then the Host 
Interface FIFO will have a request granted for up 
to four bytes. 


The Microcontroller Interface into the RAM Data 
Buffer has no FIFO available; consequently, only 
single byte requests can be transferred. 


4.3.4.4 BA16/RAS* and BA17/CAS* 
Signal Timing 


The Buffer Manager DRAM controller timing is 
specified in the Buffer Manager Timing Control 
Register (54H) as discussed in the section on 
DRAM parameter programming, Section 4.3.4.1. 
Register 54H four timing parameters yield the 
following BA16/RAS* Signal (Pin 14) and 
BA17/CAS* Signal (Pin 15) timing: 


CAS* HIGH TIME — (Register 54H, Bits 7-6). 
This field specifies the CAS* precharge time in 
DRAM Page Mode access. 


CAS* LOW TIME — (Register 54H, Bits 5-4). 
This field specifies the BA17/CAS* Signal (Pin 
15) low time in a Page Mode access. In a DRAM 
Page Mode access, the BA17/CAS* Signal (Pin 
15) low time for the very first access of the burst 
access is the BA16/RAS* Signal (Pin 14) low 
time minus one SYSCLK cycle, as in the normal 
access. For the subsequent accesses, however, 
it is specified by the BA17/CAS* Signal (Pin 15) 
low time -Bits 5-4 of Register 54H. 


RAS* HIGH TIME — (Register 54H, Bits 3-2). 
This field specifies the minimum number of 
SYSCLK cycles that the BA16/RAS* Signal (Pin 
14) is deasserted for RAS precharge. 


RAS* LOW TIME — (Register 54H, Bits 1-0). 
This field specifies the number of SYSCLK 
cycles that the BA16/RAS* Signal (Pin 14) is 
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asserted in a normal DRAM access cycle. The 
BA16/RAS* Signal (Pin 14) is asserted in phase 
2 (the second half) of the first SYSCLK cycle 
starting the access; the BA17/CAS* Signal (Pin 
15) is asserted one SYSCLK cycle later. The 
BA16/RAS* Signal (Pin 14) and the BA17/CAS* 
Signal (Pin 15) are deasserted simultaneously in 
a normal cycle. 


For read accesses of the DRAM Data Buffer, the 
Memory Output Enable Signal (MOE* - Pin 16) is 
asserted low with the first assertion of the 
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whether it is a single or multiple byte access. 
The Memory Output Enable Signal (MOE* - Pin 
16) is deasserted high along with the last 
BA17/CAS* Signal (Pin 15). For DRAM write 
accesses to the RAM Data Buffer, the Write 
Enable Signal (WE* - Pin 17) is asserted low 
with the assertion of the BA16/RAS* Signal (Pin 
14) and is deasserted high with the deassertion 
of the BA16/RAS* Signal (Pin 14). During a 
Refresh Operation neither the Memory Output 
Enable Signal (MOE* - Pin 16) nor the Write 
Enable Signal (WE”* - Pin 17) is asserted low. 


BA17/CAS* Signal (Pin 15) regardless of 


4.3.5 Hardware ECC Correction Vector Operation 


Hardware ECC correction vectors from ECC/ENDEC IC (CL-SM330) are sent to CL-SM331 through 
VECTOR Signal (Pin 23), clocked by the SYSCLK Signal (Pin 24). The serial data enters CL-SM331 
as a packet of 42 bits. 


The Error Correction Vector Packet format is as follows: 
¢ First 4 bits contain the Synchronization pattern 'D'H(1101B). 
¢ The next 22 bits contain the address for Buffer Memory access (the MSB arrives first). 
¢ After the address is the 8-bit error pattern at the packet address (the MSB arrives first). 
- The last 8 bits contain the redundancy bits. 


bit 0 bit 3 
[S3 $2... SO] 


bit 4 bit 25 
[BA21 BAZ20 ... 


bit 26 bit 33 
BAO] [EP7 EP6 ... 


bit 34 bit 41 
EPO] [RED7 RED6 ... REDO] 
Synchronization Error Pattern 


Character 


Buffer Memory 
Address 


Redundancy Bits 


Error Correction Vector Packet processing occurs independently of other operations in the CL- 
SM331. Upon the detection of Synchronization byte at VECTOR Signal (Pin 23), the VREADY Signal 
(Pin 22) is negated to stop CL-SM330 from starting any more packets. If the 8-bit error detection 
circuit verifies the data, a Read/Modify/Write access sequence of the Buffer Memory will be 
automatically scheduled. In this sequence, data will be read from Buffer Memory and then XORed 
with the 8-bit error pattern. The XORed result will be written back to Buffer Memory to complete this 
sequence. After verifying the redundancy bits of the Error Correction Vector Packet, the VREADY 
Signal (Pin 22) is asserted again to allow additional packets to be transferred. 


The VERROR Signal (Pin 21) is asserted to notify CL-SM330 either the Error Detection circuit found a 
transmission error or the Buffer Memory parity logic detected a parity error (if Buffer Memory Parity 
Enable Bit, Register 53H, Bit 3 is set) on the Buffer Read during the vector processing sequence. 


The following is the 8-bit polynomial for the Error Correction Vector Packet: 


(x84x74x241 ). 
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4.4 Sector Formatter and Format 
Sequencer Operation 


The fourth functional logic block of the CL- 
SM331 is the Sector Formatter. The Sector 
Formatter provides the disk data and control 
functions. As the block diagram on the cover 
page indicates, the Sector Formatter is 
subdivided into the Format Sequencer and the 
Sector Formatter Data path. The Sector 
Formatter Operation is managed by the Format 
Sequencer which in turn is controlled by a user- 
written program. This user-written program is 
referred to as the Format Sequencer program 
and contains the control information for the disk 
track and sector format. This program must be 
loaded into the Writable Control Store (WCS) 
before the Format Sequencer can function 
properly. The Writable Control Store (WCS) 
consists of 124 bytes that are organized as 31 
words each four bytes wide. The Format 
Sequencer program is then executed from the 
CL-SM331 Current Sequencer Word Register. 
Consequently, the Sector Formatter Current 
Sequencer Word Register actually controls the 
current disk operation and the disk interface 
output signals. Refer to Section 4.4.2 for details 
on the operation of the Format Sequencer. 


The other main component of the Sector 
Formatter is the Sector Formatter Data path. The 
Sector Formatter Data path consists of the NRZ 
data handling circuitry that includes the 
serializer/deserializer (SGERDES), the CRC error 
control logic, the SERDES parity logic, and the 
data signals to the Buffer Manager Interface. 
Refer to Section 4.4.1 for details on the operation 
of the Sector Formatter Data path. 


The Sector Formatter is capable of handling NRZ 
Data rates up to 24 Mbits/Second. All disk data 
operations such as sector reads and writes, 
format and sector verifies are executed by one or 
more of these elements of the Sector Formatter. 
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4.4.1 Components of the Sector 
Formatter Data Path 


The Sector Formatter Data path consists of the 
following seven components: 


¢ A serializer/deserializer (SERDES), 
¢ Two eight-bit comparators, 

¢ A serial synchronization detector, 
¢ Comparison circuitry, 

¢ Error Detection Logic, 

« A ten-byte stack, and 

¢ Buffer Memory parity logic. 


4.4.1.1 Serializer/Deserializer 


Disk data is read or written from the CL-SM331 
chip in a serial format. The NRZ Signal (Pin 29) 
provides the serial interface between the Sector 
Formatter Data path and the disk drive. This sig- 
nal enables the CL-SM331 chip to read and 
write NRZ Data to and from the disk drive. The 
NRZ Signal (Pin 29) is the read data input signal 
from the disk drive when the Format Sequencer 
System Read Gate Signal (Pin 25) is asserted; it 
is the write data output signal when the Format 
Sequencer System Read Gate Signal (Pin 26) is 
asserted. 


After the serial data enters the CL-SM331 it is 
processed through the Sector Formatter Data 
path Error Detection and Correction (EDAC) 
logic and is deserialized simultaneously by the 
serializer/ deserializer (SERDES). The 
SERDES appends a parity bit to each 
deserialized byte as it passes the byte on to the 
Buffer Manager. 


Data to be written out to the disk drive is either 
generated by the Format Sequencer (e.g., sync 
bytes, ID Field bytes), or it is received from the 
Buffer Manager Interface in a byte-wide format 
with optional odd parity. The SERDES checks 
the parity of the deserialized byte (if parity has 
been enabled) and then serializes the data. 
Next the serialized data is passed through to the 
CL-SM331 NRZ Signal (Pin 29). 
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4.4.1.2 Eight-Bit Comparators 


The Sector Formatter Data path has two eight-bit 
comparators that are used by the serial synch- 
ronization detector circuit, and the compare 
circuit. The compare circuit is not the same com- 
parator that is used by the serial synchronization 
detector circuit. 


The serial synchronization detector circuit uses 
one of the Sector Formatter comparators to 
search for a match between the incoming NRZ 


Data and the synchronization character which is | 


ODH (00001101B). For more details on this 
topic, refer to Section 4.4.1.3. 


The compare circuits can use the second 
comparator to compare each deserialized byte 
received with one of the following: (1) the 
Data/Branch Field of the Current Sequencer 
Word Register, or (2) the byte received from the 
Buffer Memory. For more details on the 
comparison, refer to Section 4.4.1.4. 


Both of these Sector Formatter comparators work 
in parallel with the Sector Formatter Data path 
handling of NRZ Data. Based on the results from 
these two eight-bit comparators the CL-SM331 
makes real-time decisions. 


4.4.1.3 Serial Synchronization Detector 


One of the components of the Sector Formatter 
Data path is the serial synchronization detector 
circuit. The serial synchronization detector is 
used to synchronize the Sector Formatter with 
the incoming NRZ Data stream. This circuit 
searches for a match between the eight-bit 
synchronization character (ODH, 00001101B) 
and the incoming NRZ Data stream. Whena 
match is detected, then the Format Sequencer 
logic is issued a synchronization signal. This 
synchronization signal enables the Format 
Sequencer to align itself with the incoming NRZ 
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synchronization character by writing a 1FH to the 
Format Sequencer Start Address Register (79H). 
Refer to Section 4.4.2.1 for more details. 


The serial synchronization detector circuit is 
automatically engaged when the Format 
Sequencer System Read Gate Signal (Pin 25) is 
first asserted. 


4.4.1.4 Compare Circuit 


The compare circuit is typically used for the 
Format Sequencer branch commands, and for 
verification of the Sector Data Field. This 
ability to flag specific sector or track fields for the 
microcontroller and then pass this information 
either directly or indirectly to the Format 
Sequencer supports special data handling and 
automated retry mechanisms. This comparator 
is not the same comparator used by the serial 
synchronization detector circuit. Both 
comparators, however, do work in parallel with 
the Sector Formatter Data path handling of NRZ 
Data. 


At the beginning of a disk read or write operation 
the status bit for each of these compare circuits is 
set to the equal state. When a compare 
operation is performed, the status bit is updated 
to indicate an equal or not equal state. If the 
compare circuit is not used by the Format 
Sequencer program then the compare circuit will 
remain in the equal state. 


In the case of a compare operation, the NRZ 
Read Data is compared with one of the following: 
(1) the Buffer Memory Data if a Sector Data Field 
Verify Operation has been programmed, or (2) 
the Current Sequencer Word Register 
Data/Branch Field on all bytes where the 
comparison was enabled (by setting the 
Compare Enable Bit (Writable Control Store 
(WCS) Control Field, Bit 1)). The status of the 
compare operation is available by testing the 


Data. This synchronization signal is critical following 3 bits in Register 7AH: 

because the Format Sequencer Operation is + Whenset, Bit 0 indicates 

suspended until the synchronization character is - COMPARE NOT EQUAL 

found in the incoming NRZ Data stream. This + Whenset, Bit 1 indicates 

synchronization signal also supplies the - COMPARE GREATER THAN 

SERDES with the timing information that itneedS + Whenset, Bit 2 indicates 

to convert the incoming serial data stream to - COMPARE LESS THAN 

bytes. The firmware can abort the search for the 
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4.4.1.5 Ten-Byte Stack 


Another component of the Sector Formatter Data 
path is its ten-byte, recirculating stack. If this 
stack is enabled during a read operation then 
deserialized bytes from any desired sector field 
can be pushed onto this stack. This storing of 
information enables the local microcontroller to 
read the information in a non-real time manner. 
This capability can be used for defect 
management or to pass the Sector Identification 
Field to the microcontroller. 


Because it is a ten-byte stack if more than ten 
bytes are written to the stack only the last ten 
bytes are saved. The microcontroller reads this 
stack by reading the CL-SM331 Sector 
Formatter Stack Register (7FH). The 
microcontroller reads the data from the stack in 
LIFO (Last In, First Out) order. Consequently, the 
first microcontroller read of the Sector Formatter 
Stack Register (7FH) would entail the 
microcontroller reading the last byte that was 
written onto the stack. Each read of this register 
rotates the data in a ring fashion in the stack so 
that the entire stack can be read. If more than 
ten bytes are read from the stack then the ten 
bytes of data are read continuously in a circular 
manner. For example, if the stack is read 11 
times then the stack pointer will have wrapped 
around to the top of the stack. 


4.4.1.6 Buffer Memory Parity Logic 


Buffer Memory parity is an optional error 
detection feature supported by the Sector 
Formatter Data path. This Buffer Memory parity 
function is enabled by setting the Buffer Memory 
Parity Enable Bit (Register 53H, Bit 3). For more 
details refer to Section 4.3.2. 


4.4.1.7 Error Detection Logic 


The Sector Formatter Data Path Error Detection 
logic includes a 8-bit CRC circuit. This circuit 
includes synchronization framing error 
protection. The Formatter Sequencer can 
enable the CRC circuit while it is executing the 
Formatter Sequencer program from the write 
Control Store (WCS). 
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The 8-bit CRC circuit in CL-SM331 is intended to 
protect the serial link to the CL-SM330 from 
transmission errors, such as may be induced by 
noise. The 8-bit CRC circuit is used for error 
detection only and is not used for error 
correction. Media errors are detected and 
decoded in the companion chip, the CL-SM330. 


During a read data operation, the CRC circuit 
coverage includes the Synchronization byte, 
Sector Data bytes and the CRC redundancy. 


During a write data operation, the CRC circuit 
generates the CRC redundancy for only the 
Sector Data bytes. 


If a CRC error is detected after a read data 
operation then the Data Field CRC Error Bit 
(Register 7AH, Bit 3) will be set. 


The following is the 8-bit CRC polynomial: 


(x84x/4x2+1). 


4.4.2 The Format Sequencer Operation 


The second major component of the Sector 
Formatter is the Format Sequencer. The Format 
Sequencer controls the processing of serial data 
across the disk interface. The Format 
Sequencer Operation is controlled by a user- 
written program called the Format Sequencer 
program. This program controls the timing 
relationships between the disk interface output 
signals. It also monitors the disk interface input 
lines and based on their value it makes 
decisions to branch to different locations within 
the Format Sequencer program. The Format 
Sequencer program can be programmed to 
sequence through such types of operations as 
sector read, sector write, and sector verify. The 
Format Sequencer can also be programmed for 
various types of automatic retry algorithms and 
defect management schemes. 


As the block diagram on the cover page 
indicates, one of the main components of the 
Format Sequencer is the Writable Control Store 
(WCS). The Writable Control Store (WCS), used 
to hold this Format Sequencer program, consists 
of 124 bytes that are organized as 31 words 
each four bytes wide. Each Writable Control 
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Store (WCS) word can be broken down into the 
following four eight-bit fields: (1) the Next 
Address Field, (2) the Control Field, (3) the 
Count Field, and (4) the Data/Branch Field. 
Refer to the description of the Writable Control 
Store (WCS) fields in Section 9 for details on 
each of these four fields. For details on the other 
major components of the Format Sequencer, 
refer to Section 4.4.3. 


The track layout such as gap lengths, sector size, 
and sector data fill character can be flexibly 
defined in the Format Sequencer Writable 
Control Store (WCS). 


The Format Sequencer is started by writing a 
starting address (where the Format Sequencer 
should start executing at) to the Format 
Sequencer Start Address Register (79H). The 
user can stop the Format Sequencer by writing 
the address 1FH to Register 79H. Refer to 
Section 4.4.2.1 for more details on the address 
flow of the Format Sequencer. 


4.4.2.1 Format Sequencer Address Flow 


The starting address (where the Format 
Sequencer is to begin execution) must be 
loaded into the Format Sequencer Start Address 
Register (79H). A write to Register 79H causes 
the four bytes at that Writable Control Store 
(WCS) word to be fetched from the WCS and 
then written into the Format Sequencer Current 
Sequencer Word Register. The Current 
Sequencer Word Register is a 32-bit register that 
consists of the following four eight-bit fields — the 
Next Address Field (9FH), the Control Field 
(BFH), the Count Field (DFH), and the 
Data/Branch Field (FFH). After the Writable 
Control Store (WCS) word is loaded into the 
Current Sequencer Word Register, it is executed. 
Consequently, this 32-bit Current Sequencer 
Word Register controls the current disk operation 
and the disk interface output signals. 


Each time the Sector Formatter Data path reads 
or writes an eight-bit byte the count in the 
Current Sequencer Word Register Count Field is 
decremented by one. When this Count Field 
decrements past zero (to minus one or 
underflows), another instruction word is fetched 
from the Writable Control Store (WCS) and then 
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loaded into the Current Sequencer Word 
Register. 


After the current instruction is executed, the 
source of the next address to be executed is 
dependent on the programmed branch 
command. The branch command is 
programmed in the Next Address Field (Bits 7-5) 
of the Writable Control Store (WCS), and the 
Alternate Branch Command Select Bit (Bit 7 of 
the Writable Control Store (WCS) Control Field). 


The next address that the Format Sequencer 
should go to can be obtained from any one of the 
following sources: (1) the Next Address Field, or 
(2) the Data/Branch Field, or (3) the Branch 
Address Register (78H), or (4) an implied 
address of 1FH. (Any fetch of the Writable 
Control Store (WCS) address 1FH stops the 
Format Sequencer. Therefore, the user can stop 
the Format Sequencer by writing the address 
1FH to the Format Sequencer Start Address 
Register (79H).) 


4.4.2.2 Variable Sector Data Field Size 


The CL-SM331 supports variable Sector Data 
Field sizes. The CL-SM331 uses an eight-bit 
Sector Data Field length counter to support this 
feature. When the Data Transfer Bit (Bit 0 of the 
Control Field of the Writable Control Store 
(WCS)) is set, the Count Field of the Current 
Sequencer Word Register is an_ eight-bit 
programmable counter. By setting the Count 
Field to any value from OOH to FFH a sector 
length of up to 256 bytes can be transferred 
(read from or written to the disk drive). The value 
of this counter should be programmed to be one 
less than the required sector length. 


For sector sizes greater than 256 bytes there are 
several different methods that can be used to 
define the Sector Data Field size. The most 
direct approach is to use additional Writable 
Control Store (WCS) words with each word 
processing up to 256 bytes of the Data Field. 


Another approach uses the Inhibit Data Field 
Carry Bit (Bit 4) in the Sector Formatter 
Operation Control Register (77H) and the Sector 
Size Counter (initialized by the value in the 
Sector Size Register (4EH)). In this approach 
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the Inhibit Data Field Carry Bit (Register 77H, Bit 
4) is set before the count of the Sequencer 
instruction word (that has the Data Transfer Bit 
(Control Field, Bit 0) set) has expired. The 
Format Sequencer is inhibited from going on to 
the next Sequencer word even though the 
Sector Size Counter has decremented to the last 
byte or has generated an_ underflow. 
Consequently, another 256 bytes of data are 
transferred. The initial value of the Sector Size 
Counter should be one less than the actual 
number of Count Field underflows that are to be 
suppressed. Each inhibited Count Field 
underflow decrements the Sector Size Counter. 
The Inhibit Data Field Carry Bit (Register 77H, Bit 
4) is automatically reset when the Sector Size 
Counter underflows. 


The Sector Size Counter is automatically 
initialized to the sector size value programmed in 
Register 4EH before any Sector Data Field is 
processed. Therefore, the sector size needs to 
be written only once in an initialization routine 
and only the Inhibit Data Field Carry Bit (Register 
77H, Bit 4) must be set for each Sector Data 
Field transfer. 


4.4.3 Format Sequencer Components 


The following are the main components of the 
Format Sequencer: 


« The Writable Control Store (WCS), 

¢ The Current Sequencer Word 
Register, 

¢ A Synchronization Timer, 

¢ An Input Synchronization Circuit, and 

¢ A Disk/Buffer Parity Circuit. 


For more information on the Writable Control 
Store (WCS) and the Current Sequencer 
Register, refer to Section 4.4.2. 


4.4.3.1 Synchronization Timer 


The Synchronization Timer is used to set a limit 
on the amount of time that the Format Sequencer 
is allowed to synchronize itself with the signals 
from the CL-SM330. This limit is programmed in 
the CL-SM331 Synchronization Byte-Count Limit 
Register (70H). The limit is specified in terms of 
a byte-count limit that can be from 0 to 255. Only 
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one value can be programmed into Register 
70H. When the Synchronization Timer is 
activated by the Format Sequencer program, the 
value in Register 70H is decremented for each 
byte time that passes. If the value within Register 
70H reaches zero a time-out occurs. The 
Synchronization Time-out has no direct effect on 
the Format Sequencer. 


The Synchronization Timer can be used with two 
different synchronization circuits. The first circuit 
uses this timer when the Format Sequencer is 
trying to synchronize itself to the incoming NRZ 
Data stream. The second circuit uses this timer 
when the sequencer is trying to synchronize 
itself to the rising edge of the IDF Signal (Pin 31). 


The first synchronization circuit freezes the 
Format Sequencer until the incoming NRZ Data 
stream matches the Synchronization character 
ODH (00001101B). The amount of time allowed 
for synchronization can be limited by the 
Synchronization Timer. The Synchronization 
Timer is activated by setting the Count/ Process 
CRC/Start Synchronization Timer Bit (Bit 6 of the 
Writable Control Store (WCS) Count Field) in the 
instruction word with Read Gate On active (Bits 
6-5 of the Writable Control Store (WCS) Control 
Field). If the Format Sequencer achieves 
synchronization before the Synchronization 
Timer reaches its limit, then the Format 
Sequencer proceeds normally. If the 
Synchronization Timer reaches its limit before 
the Format Sequencer’ achieves 
synchronization, then the Format Sequencer is 
immediately stopped. There is a branch 
command which modifies the reaction to a 
Synchronization Time-out. If this branch is used, 
then the Synchronization Time-out will cause the 
Format Sequencer to resume operations and 
fetch its next instruction using the Branch 
Address either specified in the Data/Branch Field 
(Register EQH-FEH, Bits 4-0) or the Branch 
Address Register (78H). 


The second synchronization circuit is activated 
by a branch condition 011 (control field Bit 7 = 1, 
and RG*CRC = 0) which freezes the Sequencer 
Operation until the rising edge of IDF Signal (Pin 
31) is detected. If the Format Sequencer 
achieves synchronization before’ the 
synchronization Timer reaches its limit, then the 
Format Sequencer continues its flow using the 
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Next Address Field (Register 80H-9EH, Bits 7-5). 
If the Synchronization Timer reaches its limit 
before the Format Sequencer achieves 
synchronization, then the Format Sequencer 
continue its flow using the Branch Address either 
specified in the Data/Branch Field (Register 
EOQH-FEH, Bits 4-0) or the Branch Address 
Register (78H). 


4.4.3.2 Input Synchronization Circuit 


CL-SM331 
SCSI Optical Disk Controller 
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The Synchronization Timer is reset when the 
RST* Signal (Pin 19) is asserted. It is 
automatically re-loaded from the 
Synchronization Byte-Count Limit Register (70H) 
after each use. 


The Input Synchronization Timer can be used when the Format Sequencer is trying to synchronize 
itself to the rising edge of the IDF Signal (Pin 31). There is a branch condition 011 (control field Bit 7 = 
1, and RG*CRC = 0) which freezes the Sequencer Operation until the rising edge of IDF Signal (Pin 
31) is detected. During this branch the Input Synchronization circuit can detect the rising edge of the 


Input Signal and protect the Input Signal from the noise. 


The following diagram shows the 


implementation of the Input rising ridge detection circuit: 


INPUT 
EDGE 
DETECT 
INPUT 
(Pin 48) 
RESET“ 
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4.4.3.3 Disk/Buffer Parity Circuit 


The disk/buffer parity circuit is another 
component of the Format Sequencer. This 
circuit enables the CL-SM331 to support data 
parity on the external RAM Data Buffer. This 
circuit can detect a parity error at the Sector 
Formatter Data path serializer/deserializer 
(SERDES) during either of the following 
operations: (1) an NRZ Write Operation, or (2) a 
Sector Data Verify Operation (a read of the RAM 
Data Buffer). 
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If the Buffer Memory Parity Enable Bit (Register 
53H, Bit 3) is set and a parity error is detected at 
the serializer/deserializer (SERDES) then the 
Disk/Buffer Parity Error Bit (Register 7AH, Bit 6) is 
set. Additionally, the CL-SM331 has a branch 
command that can be used to stop the Format 
Sequencer when a disk/buffer parity error is 
detected. Refer to the section on RAM Data 
Buffer parity, Section 4.3.2, for more details. 
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5. REGISTER ADDRESSES AND INITIALIZATION CONDITIONS 
5.1 Memory Map 


REGISTER ADDRESS — LOWER NIBBLE 
0 1 2 3 4 5 6 7 8 9 A B Cc D E F 


ses | scsi | Fo SIAN. 
4} 3 “nea? | ReG2 | PORT. NN a 


SCHED [BUFFER 
5 FFER STATUS 
DATA | CNTRL 


BUFFER] BUFFER 
MODE | TIMING 
CNTRL] CNTRL 


DISK 
ADDRESS POINTER R 
(DAP) 


ADDRESS POINTER 


~~ ON 


* 


f vo? f¢# 
fe ff as 
~~ » *S SS 
‘.) RMT 
7 . VECTOR PROCESS VECTOR | pel ae 
ADDRESS POINTER PATTERN 
N, REG REG 2 


oe? 
f?¢? 
a 
> of? 
QoQ 
x f?¢# 


Fs 
o 


REGISTER ADDRESS — UPPER NIBBLE 


e 
? 
28 g 
aa 
oz 
AYOLS TOHLNOO 318VUYEM 


aa Sana ; 
es Decoded, not implemented Not decoded, not implemented | Mutually exclusive address spaces 
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5.2 Writable Control Store (WCS) Worksheet 


Microcontroller Register Addresses 


BRANCH csssessersescisststcsitstuasseectenagpwsstenptsonsevacdaboasssconsdobteieseesesateesetassaniplbmien Standonemennd 
FORMAT ADDRESS DATA/ 
SEQUENCER REGISTER CONTROL BRANCH REG 77H 
ADDRESS (Reg. 78H) = FIELD = =F FIELD BIT1 
Oi aNvsatoaa Paasic oe ssah chuwdese OL conscaueann Bates (Pumsetea tae Si) CRESS Fe 3! 
ssa see ea cene Desai malaga es Podeeethocageb ange Naa Bonsante Bowes a ieeerren partici 
pis Ve rasteolh aaaioiegieiule ao cau me Wont ed nbieshaab anal ven Pmconerieea les ee SA erreerer) ere a. 
ch Eeneeee (enerrreners Geereer | Peerererere: Mera * beeerremet (ere C2 Lvcievsensst wane 
hie (ene Coeercneny eterety ed IVtererr trey CRaccn RAMs ame rae So iets 
i) (ees Geers Pee) ee Or ee. F aries Kem ol ee Fee: 
Le Sere ere rere.) eremerereres Seay Rermeener Pere co) eerreete eter ct 
t Loa onda adenessanees Pwaoaate ( Msaeiottvamsest \G Poudeasi a Galan: CL cageanh a linier 
sO eiareGdl eacobe ecu ialagas oe [atacmnogeet ace (anand oe con arenes Erect areenenem | 
Le Eves rere Ferrer. eemrinners rere Pererremency Pret CON sonwetoaal eats Re Vaaccencsaead ince 
i eee ererere ere perreen a) eeneeerreee Marsal Mreeereeny pene i) Mer eren Perea) reraren ee Mamet 
0, eecs Gerenc ree) prrere 12) Cememereeee enrol a Penn T ey) Ree OBL ccnaentnetd ics Rem eto reccaa diets 
Loe eee Meirmenrrrn| Perera cc] epereerer re ccd epeerrrernd Gre OO abroad eons ogee 
EA ssictsabeecateealie butane: eee Minn tainenpem nase: | saakieteaaeta aes oo) Remora Geeecrs Geeeeerener larry 
ae rere eer rere) Reeeeee 2) Ceerenrerey Greely ipeceerrerer bree oa) Feeney bree! erermemeer bree 
ey Gree Germans Prreercac| iereceernen (ere é. Poeerenceen Bere As DP ncssatienss| cexoeie 
Ok eres (eererereres) Renters, 0) beercrmere ss Ge .08) (merry Aare DO atest asco Wosae Seance doesn 
pC) ree: ever aempen i) Geeere ere: rr eer cee OAH Reermercer Clete Cameneteroes| Hare 
Ce Orr Caer ere] bene. | Meermerrer eee ccn bemenor grrr (ree 274 arererery ree io Were 
US A sensstil cnnqaioa oder eagubese Rubaanyeateud inv ee Maw nsaeanen ey eeu Oct RAP ROErEC, Preece amet remeres Heme 
AA Geers epeeerones) Preeer ind freer te Merc (eeeere ceed Pare De Ug eantatctal iat te Mosrcateeaa desl 
oP: [seve dodaaqunacra [atarravol eat eelindecehatertes asarionaying Lanse Pe Letadtannnal vats 
CCR Peery Ger rbemeeen errr.) ontermreteee NALA a Dererernre Pern DOD sisvosaeatdlas aloe vedencestt hoes 
ANE: NisshotsLapenbanaies Muresan’ Mrnsarnacesadass e-x Miia haettadi bene EA nee pore a 
LE Been eerrreey errerrces ememuerer: empl lmeerermren ber red Wrererenee! Pea ies Demeenentens kere 
Sole achs Maaentaase |e abtetes folaicunted h eaar + Bedugesocgeaa§oans ns Mrareemeeen See is Gemrmaniney: (eee 
Las eee Gener aees Wer n a) perermiree: eran Peerreeree (ee Se) eeemnerer Gere tig 
TD Niel 0s acerca aac [settee Bae iasteiatoad peat ceed Oe) CER dick! eopeeemenen: teem: 
Lo Tees (eR Finer 2 Reorereeney (cy, Hamer re Le] Feaiepewaee persed Gana ite 
a0 Dire ree er ere! Prememe 0) Wanenerne (emis! OMae ere? yet oO] Mirren peeuie 
. DE 
BITS [0:4] = NEXT 0 = DATAXFER BITS [0:5] = CNT BITS [0:7] = DATA 
ADDRESS 1 = COMP ENBL 6 = CNT/PROCESS IF REG 77H, BIT 1 =0 
BITS [5:7] 2 = OUTPUT CRC/STRT SYNC BITS [0:4] = BRANCH ADDR 
3 = INVALID NRZ TIMER IF REG 77H, BIT 1 =1 
4 = STACK ENBL 7 = CNT/PROCESS AM 
6, 5 = 00 - NO CHANGE 
01 - WG ON 
10-RG ON 
11 - WG OFF 
7 = ALT BRANCH CMDS 
(See Next Page) 
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Writable Control Store (WCS) Worksheet (cont.) 


BITS[7:5} 000 = USE NEXT ADDRESS. 
001 « STOP ON CRC ERROR, OTHERWISE USE NEXT ADDRESS. 
010 = STOP ON COMPARISON NOT EQUAL, 
OTHERWISE USE NEXT ADDRESS. 
011 = STOP ON COMPARISON NOT EQUAL OR CRC ERROR, 
AND ((CRC = 1) AND (RG = 1)) OTHERWISE USE NEXT ADDRESS. 


100 = USE BRANCH ADDRESS ON GOOD CRC AND 
COMPARISON EQUAL, OTHERWISE USE NEXT ADDRESS. 
101 = USE BRANCH ADDRESS ON CRC ERROR, OTHERWISE USE NEXT ADDRESS. 


110 = USE BRANCH ADDRESS ON COMPARISON NOT EQUAL, 
lf CONTROL OTHERWISE USE NEXT ADDRESS. 
FIELD, BIT7=0 111 = USE BRANCH ADDRESS ON COMPARISON NOT 
EQUAL OR CRC ERROR, OTHERWISE USE NEXT ADDRESS. 


000 = USE NEXT ADDRESS. 
001 = STOP IF INPUT IS ASSERTED, OTHERWISE USE NEXT ADDRESS. 
010 = STOP IF SECTOR IS ASSERTED, OTHERWISE USE NEXT ADDRESS. 
011 = STOP ON COMPARISON NOT EQUAL, OTHERWISE USE NEXT ADDRESS. 
AND ((CRC = 0) OR (RG = 0)) 100 = USE BRANCH ADDRESS. 
101 = USE BRANCH ADDRESS ON INPUT ASSERTED, OTHERWISE USE NEXT ADDRESS. 
110 = USE BRANCH ADDRESS ON SECTOR ASSERTED, OTHERWISE USE NEXT ADDRESS. 
111 = USE BRANCH ADDRESS ON COMPARISON EQUAL, OTHERWISE USE NEXT ADDRESS. 


000= RESERVED. 

001 = USE NEXT ADDRESS AND SET THE INHIBIT DATA FIELD CARRY BIT. 
010= RESERVED. 

011= RESERVED. 

100= RESERVED. 

101 = STOP ON CRC ERROR. 

AND ((CRG = 1) AND (RG = 1) USE BRANCH ADDRESS ON COMPARISON NOT EQUAL AND GOOD CRC. 
USE NEXT ADDRESS ON COMPARISON EQUAL AND GOOD CRC 


110 = STOP ON CRC ERROR. 
USE NEXT ADDRESS ON COMPARISON NOT EQUAL AND GOOD CRC. 
USE BRANCH ADDRESS ON COMPARISON EQUAL AND GOOD CRC, 


ff CONTROL 111 = USE BRANCH ADDRESS ON CRC ERROR OR COMPARISON NOT EQUAL. 
FIELD, BIT7=1 USE NEXT ADDRESS ON COMPARISON EQUAL AND GOOD CRC. 


000 = RESERVED. 

001 = STOP iF DISK BUFFER PARITY ERROR OCCURRED, OTHERWISE USE NEXT ADDRESS, 
AND SET THE INHIBIT DATA FIELD CARRY BIT. 

010= STOP IF SECTOR NOT ASSERTED, OTHERWISE USE NEXT ADDRESS. 

011 = START SYNCHRONIZATION TIMER, USE NEXT ADDRESS ON RISING EDGE OF INPUT. 

AND ((CRC = 0) OR (RG =0 )) USE BRANCH ADDRESS ON SYNCHRONIZATION TIME-OUT ERROR. 

100 = USE BRANCH ADDRESS ON SYNCHRONIZATION TIME-OUT ERROR, OTHERWISE USE 
NEXT ADDRESS. 

101 = USE BRANCH ADDRESS IF DISK BUFFER PARITY ERROR OCCURRED, OTHERWISE 
USE NEXT ADDRESS. 

110 = USE BRANCH ADDRESS IF SECTOR IS NOT ASSERTED, OTHERWISE USE NEXT ADDRESS. 

1112 RESERVED. 
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71H 
=1 
Bits 3-0 


3H| REG 4FH | REG 
1 Bit O=1 Bit 3 


5 


REGISTER | RST* | SRST*| REG 
ADDRESS Pin 40 Pin 72 Bit 5 


40H/60H W 
41H/61H 
42H/62H 
43H/63H 
44H/64H 
45H/65H 
46H/66H 
46H/66H 
47H/67H 
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NOTES: ¢t Also reset by a write to Register 79H. X means indeterminate. 
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6. SCSI INTERFACE REGISTER DESCRIPTIONS 
6.1 40H/60H — Direct SCSI Access Port (Read/Write) 
This register has no initialization conditions. 
Bits 0-7 Address 40H/60H decode allows the microcontroller direct access to the SCSI 
Data Bus. Data written to this address is stored and driven onto the SCSI Data 
Bus when the Microcontroller Direct SCSI Output Enable Bit (Register 45H/65H, 
Bit 3) is set. A microcontroller read of address 40H/60H reads the information 
directly from the SCS! Data Bus (the Microcontroller Direct SCSI Output Enable 
Bit (Register 45H/65H, Bit 3) must be reset for the SCSI Data Bus read). 
6.2 41H/61H — Selection/Reselection ID Input (Read Only) 
This register is reset when the SCSI Reset Signal (Pin 69) or the RST* Signal (Pin 19) is 
asserted low, or by a Host/Buffer Reset (Register 53H, Bit 5). 
Bits 0-7 When the SCSI Automatic Selection/Reselection Enable Bit (Register 45H/65H, 
- Bit 1) is set, after the CL-SM331 has been selected or reselected, this register 
contains the combined source and destination ID. The microcontroller should 
read this register after a selection/reselection of the device in order to determine 
the source ID. 
6.3 41H/61H — Selection/Reselection ID Output (Write Only) 
This register is reset when the SCSI Reset Signal (Pin 69) or the RST* Signal (Pin 19) is 
asserted low, or by a Host/Buffer Reset (Register 53H, Bit 5). 
Bits 0-7 When the SCSI Automatic Selection/Reselection Enable Bit (Register 45H/65H, 
Bit 1) is set, then the contents of this register are automatically driven onto the 
SCSI Data Bus during a SCSI Selection/Reselection Phase after winning the 
SCSI Arbitration Phase. The microcontroller should write the logical OR of the 
source and destination SCSI ID to Register 41H/ 61H before the SCSI 
Selection/Reselection Phase can occur. 
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6.4 42H/62H — SCSI Phase Control (Read/Write) 


This register is reset when the SCSI Reset Signal (Pin 69) or the RST* Signal (Pin 19) is 
asserted low, or by a Host/Buffer Reset (Register 53H, Bit 5). 


Bit 0 SCSI Control/Data*: Writing to this bit stores a value which is driven onto 
the SCSI Command/Data Signal (Pin 73) when the Enable Target Bit (Register 
45H/65H, Bit 4) is set, or stores the value of the expected state compared with 
the SCS! Command/Data Signal (Pin 73) when the Enable Initiator Bit (Register 
45H/65H, Bit 5) is set. The value written is logically inverted before being driven 
onto the SCSI Command/Data Signal (Pin 73) in Target Mode or compared 
with the value on the SCSI Command/Data (Pin 73) Signal in Initiator Mode. 
Reading this bit provides the logically inverted value of the SCSI 


Command/Data Signal (Pin 73). 


Bit 1 SCSI Input/Output*: Writing to this bit stores a value which is driven onto the 
SCSI! Input/Output Signal (Pin 75) when the Enable Target Bit (Register 
45H/65H, Bit 4) is set, or stores the value of the expected state compared with 
the SCSI Input/Output Signal (Pin 75) when the Enable Initiator Bit (Register 
45H/65H, Bit 5) is set. The value written is logically inverted before being driven 
onto the SCSI Input/Output Signal (Pin 75) or compared with the value on the 
SCSI Input/Output (Pin 75) Signal. Reading this bit provides the logically 


inverted value of the SCSI Input/Output Signal (Pin 75). 


Bit 2 SCSI Message: Writing to this bit stores a value which is driven onto the 
SCSI Message Signal (Pin 70) when the Enable Target Bit (Register 45H/65H, 
Bit 4) is set, or stores the value of the expected state compared with the SCSI 
Message Signal (Pin 70) when the Enable Initiator Bit (Register 45H/65H, Bit 5) 
is set. The value written is logically inverted before being driven onto the SCSI 
Message Signal (Pin 70) or compared with the value on the SCSI Message 
(Pin 70) Signal. Reading this bit provides the logically inverted value of the 


SCSI Message Signal (Pin 73). 


Bit 3 SCSI Request: The value written to this bit is logically inverted and driven 
onto the SCSI Request Signal (Pin 74) when the Enable Target Bit (Register 
45H/65H, Bit 4) is set. Reading this bit provides the logically inverted value of 


the SCSI Request Signal (Pin 74). 

Bit 4 SCSI Busy: The value written to this bit is logically inverted and driven onto 
the SCSI Busy Signal (Pin 67). This bit controls the SCSI Busy Signal (Pin 67) 
ungated by any other signals. Reading this bit provides the logically inverted 


value of the SCSI Busy Signal (Pin 67). 


Bit 5 SCSI Select: The value written to this bit is logically inverted and driven onto 
the SCSI Select Signal (Pin 72). This bit controls the SCSI Select Signal (Pin 
72) ungated by any other signals. Reading this bit provides the logically 


inverted value of the SCS! Select Signal (Pin 72). 


Bit 6 SCSI Attention: The value written to this bit is logically inverted and driven 
onto the SCSI Attention Signal (Pin 66) when the Enable Initiator Bit (Register 
45H/65H, Bit 5) is set. Reading this bit provides the logically inverted value of 
the SCSI Attention Signal (Pin 66). 
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6.4 42H/62H — SCSI Phase Control (Read/Write) (cont.) 

Bit 7 SCSI Acknowledge: The value written to this bit is logically inverted and 
driven onto the SCSI Acknowledge Signal (Pin 68) when the Enable Initiator Bit 
(Register 45H/65H, Bit 5) is set. Reading this bit provides the logically inverted 
value of the SCSI Acknowledge Signal (Pin 68). 

6.5 43H/63H — SCSI Synchronous Control (Read/Write) 

This register is reset when the SCSI Reset Signal (Pin 69) or the RST* Signal (Pin 19) is 

asserted low, or by a Host/Buffer Reset (Register 53H, Bit 5). 

Bits 0-3 Offset Count: These four binary encoded bits set the synchronous transfer 
offset count. An offset count of one to 15 can be programmed for SCSI Bus 
synchronous transfers. An offset count of zero specifies an asynchronous 
transfer. Unlimited REQ/ACK offsets are not supported. 

Synchronous Transfer Offset Count Table 

Register 43H/63H Register 43H/63H 

Bits Bits 

3. 21 0 £=0ffset 3210 #£20Offset 
0 000 s+ 0 1000s 8 
0001s: 1 1001: 9 
0010s: 2 1010 = 10 
0 011 s+ 3 ae es ae eae 
0100s 4 1100 =: 12 
010141. § 1101 + 13 
0 110s 6 1110 = 14 
0111: 7 14114114 = 15 

Bits 4-7 Synchronous Transfer Rate: These bits, in combination with the SYSCLK 
clock frequency, set the SCSI Bus synchronous transfer rate. The equation for 
determining the synchronous transfer period is shown below. 

t = SYSCLK Period 
Synchronous Transfer Period = (P * t) 
Synchronous Transfer Multiplier Table 
Register 43H/63H Register 43H/63H 
Bits Bits 
7 65 4 P 76 5 4 Pp 
0 00 0 = _ Reset State 1000 =: 9 
-RESERVED 
0 00 1 = RESERVED 1001 = 10 
0 01 0 = RESERVED 1010s2 11 
0011s 4 1011 = 12 
0 100s: 5 1100 = 13 
0101 = 6 1101 = 14 
0110s 7 1110 = 15 
Oo 111 =: 8 1 1 1 1 = RESERVED 
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6.6 44H/64H — SCSI Mode Control (Read/Write) 
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This register is reset when the RST* Signal (Pin 19) is asserted low, or by a Host/Buffer Reset 


(Register 53H, Bit 5). 


Bits 0-2 SCSI ID Bits: These bits are the CL-SM331 encoded SCS! ID. An ID of 7 
has the highest priority and an ID of 0 has the lowest. 


Register 44H/64H 


Bits 
210 SCSI ID 
00 0 0 
00 1 1 
01 0 2 
O44 3 
10 0 4 
101 5 
1 1 0 6 
ta 4 7 
Bit 3 SCSI Parity Enable: Setting this bit enables the SCSI parity checking 
circuitry. The CL-SM331 always generates odd parity onto the SCS! Bus. 
Bit 4 SCSI Logic Clock Disable: The user must program this bit to be reset. 


When this bit is set, the internal SCSI logic clock is disabled. It is used for test 


purposes. 


Bits 5-7 SCSI Logic Clock Prescalar: These bits specify the clock used for the 
SCSI Phase logic. The specified clock period should be within the range of 200 


ns - 400 ns. 


Register 44H/64H 
Bits 

76 5 

00 0 = SYSCLK/2 

00 1 = SYSCLK/4 

0 10 = SYSCLK/6 

O 1 1 = SYSCLK/8 


Register 44H/64H 


Bits 
7 6 5 
1 0 0 = SYSCLK/10 
101 = SYSCLK/12 
1 1 0 = SYSCLK/14 
1 1 1 = SYSCLK/16 
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45H/65H — SCSI Operation Control (Read/Write) 


This register is reset when the SCSI Reset Signal (Pin 69) or the RST* Signal (Pin 19) is 
asserted low, or by a Host/Buffer Reset (Register 53H, Bit 5). 


Bit 0 Arbitration/Selection Start: When this bit is set, the CL-SM3321 will 
proceed to gain control of the SCSI Bus through automatic implementation of a 
successful SCSI Arbitration Phase. As long as arbitration is impossible due to 
SCSI Bus activity or a SCSI Arbitration Phase has been lost, the CL-SM331 will 
continue to monitor the SCSI Bus to attempt arbitration until a SCSI Arbitration 
Phase is won or until this bit is reset. 


Bit 1 SCSI Automatic Selection/Reselection Enable: When set, this bit 
enables the CL-SM331 to respond automatically to being selected or 
reselected. Also when this bit is set, the CL-SM331 is able to proceed 
automatically to either a SCS/ Selection or Reselection Phase after winning the 
SCSI Arbitration Phase. A microcontroller reset of this bit will abort the 


selection/reselection process. 


Bit 2 SCSI Automatic Selection/Reselection Mode: If the SCSI Automatic 
Selection /Reselection Enable Bit (Bit 1) is set and this bit is set, the CL-SM331 
will automatically proceed to a SCSI Selection Phase after arbitration is won; 
and if this bit is reset, the CL-SM331 will proceed to a SCSI Reselection Phase. 


Bit 3 Microcontroller Direct SCSI Output Enable: When this bit is set and the 
Enable Target or the Enable Initiator Bit (Bit 4 and Bit 5, respectively) is set, the 
CL-SM331 will drive the contents of the Direct SCSI Access Port (Register 
40H/60H) onto the SCSI Data Bus (Pins 54-57, 59-62). Parity will be gated 


onto the SCSI Data Bus Parity Signal (Pin 63). 


Bit 4 Enable Target: SCSI outputs on phase and handshake signals controlled by 
a Target are enabled when this bit is set. This bit need only be set by the local 
microcontroller for firmware controlled operations, as this will be set and reset 
throughout real-time automatic operations under the control of the CL-SM331 
logic. A SCSI Bus Free Phase will inhibit setting this bit, either the SCS! Busy 
Signal (Pin 67) or the SCSI Select Signal (Pin 72) must be asserted low on the 
SCSI Bus to allow this bit to be set. 


Bit 5 Enable Initiator: SCSI outputs on control and handshake signals controlled 
by an Initiator are enabled when this bit is set. This bit need only be set by the 
local microcontroller for firmware controlled operations, as this will be set and 
reset throughout real-time automatic operations under the control of the CL- 
SM331 logic. A SCSI Bus Free Phase will inhibit setting this bit, either the 
SCSI Busy Signal (Pin 67) or the SCSI Select Signal (Pin 72) must be asserted 
low on the SCSI Bus to allow this bit to be set. 


Bit 6 SCSI Active Pull-Up Select: Setting this bit enables the active pull-up on 
SCSI Bus signals. Resetting this bit selects open drain on all SCSI outputs 


except REQ* (pin 74) and ACK* (pin 68). 


Bit 7 SCSI Reset Out: When this bit is set, the SCSI Reset Signal (Pin 69) will be 
asserted low. 
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6.8 46H/66H — SCSI Status Register 1 (Read/Write) 


When the SCSI Reset Signal (Pin 69) is asserted low, it sets Bit O and resets Bits 1-5 of this 
register. Bits 0-5 are reset when the RST“ Signal (Pin 19) is asserted low, or by a Host/Buffer 
Reset (Register 53H, Bit 5). Bits 0-5 must be reset by the microcontroller by writing a one to 
that bit, thus clearing interrupts (if enabled in Register 47H/67H and Register 4FH, Bits 1 and 
6) and receiving further updated status. 


Bit 0 SCSI Reset Detected: This bit reflects the SCSI Reset Signal (Pin 69) 
history. When this bit is set, a SCSI Reset has occurred and can still be in effect 
since this bit was last reset. 


Bit 1 SCSI Attention Detected: This bit reflects the SCSI Attention Signal (Pin 
66) history. When this bit is set, a SCSI Attention assertion has been detected 
and can still be in effect since this bit was last reset. 


Bit 2 SCSI Offset Overrun/Underrun Detected: When this bit is set, it indicates 
that in SCSI synchronous transfer mode an offset overrun/ underrun was 
detected. 

Bit 3 SCSI Bus Free Detected: When this bit is set, it indicates that a SCSI Bus 
Free Phase has been detected since this bit was last reset. 

Bit 4 SCSI/Buffer Parity Error Detected: This bit reflects the error history for 


transfers from the buffer memory to the SCSI interface. When this bit is set, a 
parity error was detected transferring data from the buffer memory to the internal 
SCSI interface. 


Bit 5 SCSI Bus Parity Error Detected: This bit reflects the SCSI Bus parity error 
history. When this bit is set, a SCSI Bus parity error was detected. 


Bit 6 SCSI Parity Error: This bit reflects odd parity of the internal SCSI Bus. The 
user is responsible to ensure that data is stable on the internal SCSI! Bus for this 
signal to have a valid state. 


Bit 7 SCSI RST In: This bit reflects the logically inverted state of the SCSI Reset 
Signal (Pin 69). 


—e 
SS CL-SM331 
nerennae nn EIT e ° 
CIRRUS LOGIC SCSI Optical Disk Controller 
6.9  47H/67H — SCSI Interrupt Enable Register 1 (Read/Write) 
This register is reset when the RST* Signal (Pin 19) is asserted low or by a Host/Buffer Reset 
(Register 53H, Bit 5). 
Bit 0 SCSI Reset Detected Enable: When this bit set, it causes the HINT Signal 
(Pin 33) to be asserted low when the SCSI Reset Detected Bit (Register 
46H/66H, Bit 0) is set. 
Bit 1 Attention Detected Enable: When this bit is set, it causes the HINT Signal 
(Pin 33) to be asserted low when the SCSI Attention Detected Bit (Register 
46H/66H, Bit 1) is set. 
Bit 2 Offset Overrun/Underrun Enable: When this bit is set, it causes the HINT 
Signal (Pin 33) to be asserted low when the SCSI Offset Overrun/Underrun 
Detected Bit (Register 46H/66H, Bit 2) is set. 
Bit 3 SCSI Bus Free Detected Enable: When this bit is set, it causes the HINT 
Signal (Pin 33) to be asserted low when the SCSI Bus Free Detected Bit 
(Register 46H/66H, Bit 3) is set. 
Bit 4 SCSI/Buffer Parity Error Enable: When this bit is set, it causes the HINT 
Signal (Pin 33) to be asserted low when the SCSI/Buffer Parity Error Detected 
Bit (Register 46H/66H, Bit 4) is set. 
Bit 5 SCSI Bus Parity Error Enable: When this bit is set, it causes the HINT 
Signal (Pin 33) to be asserted low when the SCSI Bus Parity Error Detected Bit 
(Register 46H/ 66H, Bit 5) is set. 
Bits 6-7 RESERVED. 
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6.10 48H — SCSI Status Register 2 (Read/Write) 


This register is reset when the SCSI Reset Signal (Pin 69) or the RST* Signal (Pin 19) is 
asserted low, or by a Host/Buffer Reset (Register 53H, Bit 5). Each bit must be reset by the 
microcontroller by writing a one to that bit, thus clearing interrupts (if enabled in Register 49H 
and Register 4FH, Bits 1 and 6) and receiving further updated status. 


Bit 0 Device Selected: When this bit is set, the CL-SM331 has answered a SCSI! 
selection attempt since this bit was last reset. When the SCSI Automatic 
selection/Reselection Enable Bit (Register 45H/65H, Bit 1) is set, the CL- 
Siete will detect the combination of: 
the SCSI Select Signal (Pin 72) asserted low, 

¢ the SCSI Busy Signal (Pin 67) deasserted high, 

¢ the SCSI Input/Output Signal (Pin 75) deasserted high, 

« the CL-SM331 SCSI ID (Register 44H/64H, Bits 0-2) is asserted on the SCSI Data Bus (Pins 
54-57, 59-62), 

° no more than two ID bits are asserted on the SCSI Data Bus (Pins 54- 57, 59-62), 

¢« SCSI parity is correct (if the SCSI Parity Enable Bit (Register 44H/64H, Bit 3) is set) and 

- the SCSI Reset Signal (Pin 69) is deasserted high. 


The detection of the above combination will: 

* set this bit (Device Selected), 

- — set the Enable Target Bit (Register 45H/65H, Bit 4) 

* assert low the SCSI Busy Signal (Pin 69 and Register 42H/62H, Bit 4) and 

« latch the SCSI Data Bus (Pins 54-57, 59-62) (accessible in the Selection/Reselection ID Input 


Register (41 H/61 H)). 


Bit 1 Device Reselected: When this bit is set, the CL-SM331 has answered a 
SCSI reselection attempt since this bit was last reset. When the SCSI 
Automatic Selection/Reselection Enable Bit (Register 45H/65H, Bit 1) is set, the 


esi SM331 will detect the combination of: 
the SCSI Select signal (Pin 72) asserted low, 

¢ the SCSI Busy Signal (Pin 67) deasserted high, 

* the SCSI Input/Output Signal (Pin 75) asserted low, 

* the CL-SM331 SCSI ID (Register 44H/64H, Bits 0-2) is asserted on the SCSI Data Bus (Pins 
54-57, 59-62), 

* exactly two ID bits are asserted on the SCSI Data Bus (Pins 54-57, 59-62), 

*- SCSI parity is correct (if the SCSI Parity Enable Bit (Register 44H/64H, Bit 3) is set) and 

« the SCSI Reset Signal (Pin 69) is deasserted high. 


The detection of the above combination will: 
- set this bit (Device Reselected), 


* assert low the SCSI Busy Signal (Pin 69 and Register 42H/62H, Bit 4) until the SCSI Select 
Signal (Pin 72) is asserted low 


e — set the Enable Initiator Bit (Register 45H/65H, Bit 5) and 
« latch the SCSI Data Bus (Pins 54-57, 59-62) (accessible in the Selection/Reselection ID Input 


Register (41 H/61 H)). 
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6.10 48H — SCSI Status Register 2 (Read/Write) (cont.) 


96 


Bit 2 Arbitration Won: When this bit is set, it indicates that a requested SCSI 
Arbitration Phase has been won by the CL-SM331 since this bit was last reset. 
If the SCS! Automatic Selection/ Reselection Enable Bit (Register 45H/65H, Bit 
1) is set then the CL-SM331 will proceed to the SCS! Selection or Reselection 
Phase depending on the value programmed in the SCSI Automatic 


__Selection/Reselection Mode Bit (Register 45H/65H, Bit 2). 


Bit 3 Automatic Selecting/Reselecting Done: When this bit is set, it indicates 
that the automatic SCSI Selection/Reselection Phase is completed. 
Bit 4 Transfer Done: When this bit is set, it indicates the completion of a SCSI 


transfer. Note that when this bit is set, it also means that the last SCSI 
handshake has been completed, and/or the last buffer memory cycle is 


completed. This is valid for DMA or Programmed I/O (PIO) transfers. 


Bit 5 Transfer Halted: When this bit is set, it indicates that a SCSI transfer was 
halted due to either a microcontroller halt request done by resetting the DMA 


Start Bit (Register 52H, Bit 1) or a phase mismatch in Initiator Mode. 


Bit 6 SCSI Phase Mismatch: When this bit is set, it indicates that SCSI 
Command/Data Signal (Pin 73), the SCSI Input/Output Signal (Pin 79), and the 
SCSI Message Signal (Pin 70) do not match the expected phase (Register 
42H/62H, Bits 0-2) as programmed by the Initiator (the Enable Initiator Bit 


(Register 45H/65H, Bit 5) is set). 


Bit 7 Req-On: When this bit is set, it indicates that assertion low of the SCSI! 
Request Signal (Pin 74) has been detected since this bit was last reset. This 
function is enabled only when the Enable Initiator Bit (Register 45H/65H, Bit 5) 
is set. 
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6.11 49H — SCSI Interrupt Enable Register 2 (Read/Write) 


This register is reset when the RST* Signal (Pin 19) is asserted low or by a Host/Buffer Reset 
(Register 53H, Bit 5). 


Bit 0 Device Selected Enable: When this bit is set, it causes the HINT Signal 
(Pin 33) to be asserted low when the Device Selected Bit (Register 48H, Bit 0) is 
set. f 

Bit 1 Device Reselected Enable: When this bit is set, it causes the HINT Signal 
(Pin 33) to be asserted low when the Device Reselected Bit (Register 48H, Bit 1) 
is set. 

Bit 2 Arbitration Won Enable: When this bit is set, it causes the HINT Signal (Pin 
33) to be asserted low when the Arbitration Won Bit (Register 48H, Bit 2) is set. 

Bit 3 Automatic Selecting/Reselecting Enable: When this bit is set, it causes 


the HINT Signal (Pin 33) to be asserted low when the Automatic 
Selecting/Reselecting Done Bit (Register 48H, Bit 3) is set. 


Bit 4 Transfer Done Enable: When this bit is set, it causes the HINT Signal (Pin 
33) to be asserted low when the Transfer Done Bit (Register 48H, Bit 4) is set. 

Bit 5 Transfer Halted: When this bit is set, it causes the HINT Signal (Pin 33) to be 
asserted low when the Transfer Halted Bit (Register 48H, Bit 5) is set. 

Bit 6 SCSI Phase Mismatch Enable: When this bit is set, it causes the HINT 


Signal (Pin 33) to be asserted low when the SCSI Phase Mismatch Bit (Register 
48H, Bit 6) is set. 


Bit 7 Req-On Enable: When this bit is set, it causes the HINT Signal (Pin 33) to be 
asserted low when the Req-On Bit (Register 48H, Bit 7) is set. 


6.12 4AH — Microcontroller SCSI FIFO Access Port (Read/Write) 


This register has no initialization conditions. 


Bits 0-7 The register is the microcontroller SCSI FIFO access port. Writing to this 
address writes the microcontroller data to the FIFO, and reading this address 
puts the FIFO output onto the microcontroller Data Bus. 
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7. BUFFER MANAGER REGISTER DESCRIPTIONS 
7.1 50H — Scheduled Buffer Data (Read/Write) 

This register is reset when the RST* Signal (Pin 19) is asserted low, or by a Host/Buffer Reset 

(Register 53H, Bit 5). 

Bits 0-7 The local microcontroller uses this register to access the buffer memory (using 
the Disk Address Pointer). Data can be either read or written through this regis- 
ter. Additionally, the configuration switches on the buffer memory Data Bus are 
also read through this register (using the MOE Disable Bit (Register 53H, Bit 4)). 

7.2 51H — Buffer Status/Control Register (Read/Write) 

This register is reset when the RST* Signal (Pin 19) is asserted low, or by a Host/Buffer Reset 

(Register 53H, Bit 5). 

Bits 0-3 Synchronous Data Transfer Offset: A microcontroller read of Bits 0-3 give 
the running synchronous offset count (Read Only). 

Register 51H Register 51H 

Bits Current Bits Current 
3 210 Offset 3210 Offset 
0000s 0 1000 = 8 
0001s 1 1001 = 9 
0010 s+ 2 1010 = 10 
0011s. 3 10141 «= 11 
0100s 4 1100 <= 12 
0101s 5 1101 = 13 
0110s 6 1110 = 14 
Oa es 27 | ae ee ee ae 

Bit 4 Clear FIFO: When this bit is set, it causes the FIFO to be cleared. This bit 
must be reset before any access to the FIFO is attempted. 

Bit 5 SCSI Data Set Up Select: This bit selects the SCSI Data set-up time in 
asynchronous mode, referenced to the SYSCLK period, t. 

Bit 5 SCSI Data Set-Up Time 
0 t 
1 at 
NOTE: This is a logical value rather than an absolute value. See the AC 
parameters (Section 11.3) for specific data set-up times. 
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Bit 6 DRAM Burst Enable: When this bit is set, it forces the Buffer Manager logic 
to perform disk and host DRAM page mode accesses in bursts of four (except 
for the last burst of the transfer). If this bit is reset, DRAM page mode accesses 
are issued as required depending on the host and disk transfer rates. This bit 
must be disabled (set to 0) when in SRAM Mode or when in Initiator Mode 
performing synchronous data transfers with a programmed offset, Bits 0-3, less 
than four. 


Bit 7 Reserved for test purposes. This bit should be reset. 


7.3 52H — Buffer Transfer Control (Read/Write) 


This register is reset when the SCSI Reset Signal (Pin 69) or the RST“ Signal (Pin 19) is 
asserted low, or by a Host/Buffer Reset (Register 53H, Bit 5). 


Bit O Enable Buffer Segmentation: When this bit is set, it configures the buffer 
memory as 64K bytes segments on 64K bytes boundaries with the 4 MSBs of 


the address designating the segment. 


Bit 1 DMA Start: When this bit is set, the CL-SM331 starts a DMA transfer. The 
direction is programmed in the SCSI R/W* Transfer Direction Bit (Bit 3). This bit 
is reset when (a) the transfer is completed, or (b) the CL-SM331 is in the 
Initiator Mode, the SCSI Phase does not match the expected phase, and the 
SCSI Request Signal (Pin 74) is asserted low on the SCSI Bus. A reset of this 
bit by the microcontroller causes a DMA halt in Target Mode only. 


Bit 2 PIO Start: When this bit is set, the CL-SM331 starts transfers through the 
FIFO. The transfer byte count is specified by the PIO Transfer Count, Bits 4-7. 
This bit is reset when (a) the transfer is completed, or (b) the CL-SM331 is in 
the Initiator Mode, the SCS] Phase does not match the expected phase, and the 
SCSI Request Signal (Pin 74) is asserted low on the SCSI Bus. 


Bit 3 SCSI R/W* Transfer Direction: This bit indicates the direction of 
information transfer on the SCSI Bus in both the Programmed I/O (PIO) and 
DMA transfer modes. When this bit is set, information is transferred from the CL- 
SM331. When this bit is reset, information is transferred to the CL-SM331. 
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52H — Buffer Transfer Control (Read/Write) (cont.) 


Bits 4-7 PIO Transfer Count: The value written to these bits is the number of bytes to 


be transferred under Programmed I/O (PIO). A microcontroller read of these bits 
gives the running count of bytes to be transferred under Programmed I/O (PIO). 
Register 52H Register 52H 

Bits PIO Bits PIO 

6 5 Transfer Count 6 5 Transfer Count 

8 

9 


| 
“ 
py 


4 
0 
1 
0 
1 
0 
1 
0 
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53H — Buffer Mode Control (Read/Write) 


When the RST™ Signal (Pin 19) is asserted low, Bits 5-7 of this register are set and Bits 0-4 
are reset. 


Bit 0 DRAM/SRAM*: This bit selects the Buffer Manager Mode of operation. When 
this bit is set, the DRAM Mode is selected. When this bit is reset, the SRAM 
Mode is selected. 


Bits 1-2 DRAM Type: These bits select the size of DRAM for buffer memory. The sizes 


supported are 64K, 256K, and 1M DRAMS as shown below: 


Register 53H 
Bits Description 


0 0 64K DRAM 
0 1 256K DRAM 
1 0 1M DRAM 
ie 4M DRAM 


Bit 3 Buffer Memory Parity Enable: Setting this bit enables the buffer memory 


parity checking circuit on every read access of the buffer memory. The checking 
is enabled for buffer memory reads whether the destination is the Host SCSI 
port or the disk SERDES logic. The CL-SM331 generates odd parity on every 
buffer memory write access regardless of the state of this bit. The SCSI Bus 
parity value is passed through the CL-SM331 to the Buffer Data Parity Signal if 
the SCSI Parity Enable Bit (Register 44H/64H, Bit 3) is set; otherwise, the odd 
parity value from the SCSI Bus Data is generated. Odd parity is always 
generated from the 8-bit deserialized data from the disk. 
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Bit 4 MOE Disable: When this bit is set, the MOE* Signal (Pin 16) in SRAM Mode 
and the MOE* Signal (Pin 16), the BA16/RAS* Signal (Pin 14), and the 
BA17/CAS* Signal (Pin 15) in DRAM Mode are disabled. This is intended to 
support switch reads (via the Scheduled Buffer Data Register (50H)) of the 


buffer memory Data Bus. 


Bit 5 Host/Buffer Reset: Assertion of the RST* Signal (Pin 19) sets this bit and 
generates a hardware reset condition. When this bit is set by the micro- 
controller, a software reset condition is generated. Either reset stops all opera- 
tions in the Buffer Manager and SCSI Host Logic. The software reset initializes 
Registers 40H/60H-47H/67H, 48H, 49H, 50H, 52H, and 57H-5FH. All SCSI! 
signals are switched to a high-impedance state. The Buffer Manager signals 


are unaffected by a software reset. 


Bits 6-7 Wait States: These bits select the number of wait states the Ready Signal 
(Pin 38) is deasserted for accessing the CL-SM331 internal registers. One wait 
State is defined to be ‘t’, the period of the SYSCLK Signal (Pin 24). The Ready 
Signal (Pin 38) is asserted with respect to the ALE Signal (Pin 51). The number 
of wait states as listed below is measured from the assertion of the Read Strobe 
Signal (Pin 37), the Write Strobe Signal (Pin 36), or the Data Strobe Signal (Pin 


37). 
Register 53H 

Bits Description 
7 6 


0 0 No wait States 
0 1 1-2 wait States 
1 0 2-3 wait States 
1 1 3-4 wait States 


ee. 
annem 
enero EET ERE, 


ca as 


CL-SM331 


IRRUS LOGIC SCSI Optical Disk Controller 


=——_<@ 


slefolatetetetetetetatetetetetetetatetetetatetetetetetetetetasetereresetetelatetetetetetetetatetetetetetatatotareleteteteretetetetsterotatetetestetetatatateteteletetstetetetetetetetetetee 
nInseaacededuia receded ateceasteseeatasatetetatetetateteteteteteteretscatatetererstetetetetatstetetetetetetstetetetetarerstetetareteteteteterteteteteteteteretatetetetstatetateretstetetete 


7.5 54H — Buffer Manager Timing Control (Read/Write) 


This register is reset when the RST* Signal (Pin 19) is asserted low. 


Bits 0-1 


Bits 2-3 


Bits 4-5 


Bits 6-7 


RAS* Low Time/SRAM Cycle Time: When DRAM is used, this field 
specifies the number of SYSCLK cycles the BA16/RAS* Signal (Pin 14) is 
asserted in a non-page mode DRAM access cycle. When SRAM is used, this 
field specifies the SRAM cycle time. 

t = SYSCLK Period 


RAS* Low Time, tWRL = 
Bits Bits Bits Bits 


10 10 1 0 1 0 
0 O=2t 0 1=3t 1 O=4t 1 1=5t 


SRAM Buffer Access Time, tWBA = 
Bits Bits Bits Bits 


10 10 1 0 1 0 
0 0=2t 0 1=3t 1 O=4t 1 1=5t 


RAS* High Time: When DRAM is used, this field specifies the minimum 
number of SYSCLK cycles the BA16/RAS* Signal (Pin 14) is deasserted (RAS 
precharge time). | 

t = SYSCLK Period 


RAS* High Time, tWRH = 


Bits Bits Bits — Bits 
3 2 32 3.20 3 2 
0 O=t 0 1=2t 1 O=3t 1 1=4t 


CAS* Low Time: When DRAM is used, this field specifies the number of 
SYSCLK cycles the BA17/CAS* Signal (Pin 15) is asserted in a DRAM page 
mode access. 


t = SYSCLK Period 
CAS* Low Time, tWCL = 


Bits Bits Bits Bits 
5 4 5 4 5 4 5 4 
0 O=t Q 1=2t 1 O=3t 1 1=4t 


CAS* High Time: When DRAM is used, this field specifies the minimum 
number of SYSCLK cycles the BA17/CAS* Signal (Pin 15) is deasserted in a 
DRAM page mode access. 


t = SYSCLK Period 
CAS* High Time, tWCH = 


Bits Bits Bits Bits 
7 6 7 6 7 6 7 6 
0 O=t 0 1=2t 1 O=3t 1 1=4t 
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7.6 55H — DRAM Refresh Period (Read/Write) 


This register is reset when the RST™* Signal (Pin 19) is asserted low. 


Bits 0-7 This register holds the most significant 8 bits of the 9-bit refresh period, the one 
least significant bit (inaccessible) is always set. The refresh period is specified 
in the number of SYSCLK cycles. 


7.7 56H — Buffer Size (Read/Write) 


This register is reset when the RST™ Signal (Pin 19) is asserted low. 


| BUFFER SIZE | 


OOH = 2K bytes 

01H = 8K bytes 

03H = 16K bytes 

07H = 32K bytes 

OFH = 64K bytes 

1FH = 128K bytes 
3FH = 256K bytes 
7FH = 1 Mbytes 

FFH = 4Mbytes 

Bits 0-7 This register specifies the size of the physical buffer memory (in bytes) where 


the codes for a given buffer size are in the table above. The value programmed 
in this register controls the comparison of the Host Address Pointer (HAP— 
Registers 5AH-5CH) and the Stop Address Pointer (GAP—Registers 5DH-5FH). 
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57H — Disk Address Pointer Low (DAPL) (Read/Write) 


This register is reset when the RST“ Signal (Pin 19) is asserted low, or by a Host/Buffer Reset 
(Register 53H, Bit 5). 


Bits 0-7 This register is the low-order byte of the buffer memory address for disk and 
microcontroller accesses. 


58H — Disk Address Pointer Middle (DAPM) (Read/Write) 


This register is reset when the RST“ Signal (Pin 19) is asserted low, or by a Host/Buffer Reset 
(Register 53H, Bit 5). 


Bits 0-7 This register is the middle-order byte of the buffer memory address for disk and 
microcontroller accesses. 


59H — Disk Address Pointer High (DAPH) (Read/Write) 


This register is reset when the RST“ Signal (Pin 19) is asserted low, or by a Host/Buffer Reset 
(Register 53H, Bit 5). 


Bits 0-5 These bits are the high-order byte of the buffer memory address for disk and 
microcontroller accesses. 


Bits 6-7 RESERVED. 
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7.11 5AH — Host Address Pointer Low (HAPL) (Read/Write) 


This register is reset when the SCSI Reset Signal (Pin 69) or the RST* Signal (Pin 19) is 
asserted low, or by a Host/Buffer Reset (Register 53H, Bit 5). 


Bits 0-7 This register is the low-order byte of the buffer memory address for host 
accesses. 


7.12 5BH — Host Address Pointer Middle (HAPM) (Read/Write) 


This register is reset when the SCSI Reset Signal (Pin 69) or the RST* Signal (Pin 19) is 
asserted low, or by a Host/Buffer Reset (Register 53H, Bit 5). 


Bits 0-7 This register is the middle-order byte of the buffer memory address for host 
accesses. 


7.13 5CH — Host Address Pointer High (HAPH) (Read/Write) 


This register is reset when the SCSI Reset Signal (Pin 69) or the RST” Signal (Pin 19) is 
asserted low, or by a Host/Buffer Reset (Register 53H, Bit 5). 


Bits 0-5 These bits are the high-order byte of the buffer memory address for host 
accesses. 
Bits 6-7 RESERVED. 
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7.14 5DH — Stop Address Pointer Low (SAPL) (Read/Write) 


~“ 


.16 
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This register is reset when the SCSI Reset Signal (Pin 69) or the RST* Signal (Pin 19) is 
asserted low, or by a Host/Buffer Reset (Register 53H, Bit 5). 


Bits 0-7 This register is the low-order byte of the Stop Address Pointer (SAP) for host 
accesses. 


5EH — Stop Address Pointer Middle (SAPM) (Read/Write) 


This register is reset when the SCSI Reset Signal (Pin 69) or the RST* Signal (Pin 19) is 
asserted low, or by a Host/Buffer Reset (Register 53H, Bit 5). 


Bits 0-7 This register is the middle-order byte of the Stop Address Pointer (SAP) for host 
accesses. 


5FH — Stop Address Pointer High (SAPH) (Read/Write) 


This register is reset when the SCSI Reset Signal (Pin 69) or the RST* Signal (Pin 19) is 
asserted low, or by a Host/Buffer Reset (Register 53H, Bit 5). 


Bits 0-5 These bits are the high-order byte of the Stop Address Pointer (SAP) for host 
accesses. 


Bits 6-7 RESERVED. 
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8. SECTOR FORMATTER REGISTER DESCRIPTIONS 
8.1 4EH — Sector Size (Read/Write) 
This register is reset when the RST“ Signal (Pin 19) is asserted low. 
Bits 0-7 Writing to this register sets the number of 256 byte data blocks to be transferred 


by the Format Sequencer when the Inhibit Data Field Carry Bit (Register 77H, 
Bit 4) is used. The value programmed should be one less than the number of 
underflows of the Current Sequencer Word Count Field that will be inhibited. 
With this register set to OOH, and the Inhibit Data Field Carry Bit (Register 77H, 
Bit 4) set, only one underflow of the Current Sequencer Word Count Field will 
be inhibited. 


For a 532-byte Data Field, set the Count Field of the Format Sequencer word to 
13H, set this register to 01H, and set the Inhibit Data Field Carry Bit (Register 
77H, Bit 4). 
For a 4096-byte Data Field, set the Count Field of the Format Sequencer word 
to FFH, set this register to OEH, and set the Inhibit Data Field Carry Bit (Register 
77H, Bit 4). 


April 1991 [ES a SN MR Ie 67 


a 
—S==== CL-SM331 
one e ° 
CIRRUS LOGIC SCSI Optical Disk Controller 
8.2 4FH — Sector Formatter Mode Control (Read/Write) 
_ This register is reset (except for Bit 0 which will be set) when the RST* Signal (Pin 19) is 
asserted low. 

Bit 0 Sector Formatter Reset: When the RST* Signal (Pin 19) is asserted low, 
this bit is set and generates a hardware Reset condition. When this bit is set by 
the microcontroller, a software Reset condition is generated. Either reset stops 
all operations in the Sector Formatter. The software Reset initializes Registers 
71H-76H, 78H-7EH, 9FH, BFH, DFH, FFH, deasserts the Read Gate Signal (Pin 
25), the Write Gate Signal (Pin 26), and switches the NRZ Signal (Pin 29) to a 
high-impedance state. The Sector Formatter will remain in the Reset condition 

| as long as this bit is set. The Reset condition can be removed by resetting this 
bit. Refer to the section on register reset conditions (Section 5.3). 

Bit 1 Local HINT Enable: When this bit is set, it enables local interrupt capability 
on the HINT Signal (Pin 33). The individual sources of interrupts can still be 
disabled by the Interrupt Enable Registers (Registers 47H/67H and 49H). 

Bit 2 Local DINT Enable: When this bit is set, it enables local interrupt capability 
on the DINT Signal (Pin 32). The individual sources of interrupts can still be 
disabled by the Sector Formatter Interrupt Enable Register (7EH). 

Bit 3 Local Int Pin Pull-Up Disable: When this bit is set, it disables the pull-up 
on both the HINT Signal (Pin 33) and the DINT Signal (Pin 32), leaving an open 
drain output. This is intended to support system-level, multiple interrupt 
SOUICEeS. | 

Bit 4 SCSI Interface Register Decode Select: When this bit is set, the address 
space 40H-47H is decoded. When this bit is reset, the address space 60H-67H 
is decoded. After a Sector Formatter Reset, decode of both address spaces is 
disabled until this register is written. 

Bit 5 Interrupt Polarity: When this bit is set, it selects active low on the interrupt 
pins DINT (Pin 32) and HINT (pin 33). When this bit is reset, which is the default 
condition, it selects active high on the interrupt pins DINT (pin 32) and HINT (pin 
33). When the interrupt pins are programmed active high, it will override the 
open drain configuration even if the pull-ups are disabled by the Local Int Pin 
Puill-Up Disable Bit (Register 4F, Bit 3). 

Bit 6 Local Int Mode Enable: When this bit is set, it routes both the HINT and 
DINT internal Signals to the DINT Signal (Pin 32) and disables any output to the 
HINT Signal (Pin 28). 

Bit 7 RESERVED. 
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8.3 70H — Synchronization Byte-Count Limit (Read/Write) 


This register is reset when the RST“ Signal (Pin 19) is asserted low. 


Bits 0-7 This register holds the byte-count limit for NRZ Read Data synchronization 
attempts. This value is programmable from 0 to 255. Refer to the description of 
the Count/Process CRC/Start Synchronization Timer(Bit 6 of the Writable 
Control Store (WCS) Count Field) (Section 9.3). When the timer has been 
activated, the value is decremented for each byte time that passes. If the value 
reaches zero, the Synchronization Time-Out Error Bit (Register 7AH, Bit 4) is 
set. Reading this register provides the running count (if the timer is active), or 


the programmed limit if the timer is inactive. 


8.4 71H — Vector Process Address Pointer (VAPL) (Read Only) 


This register is reset when the RST* Signal (Pin 19) is asserted low. 


Bits 0-7 This register is the low-order byte of the buffer memory address for vector 
process. 


8.5 72H — Vector Process Address Pointer (VAPM) (Read Only) 


This register is reset when the RST* Signal (Pin 19) is asserted low. 


Bits 0-7 This register is the middle-order byte of the buffer memory address for vector 
process. 
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73H — Vector Process Address Pointer (VAPH) (Read Only) 


This register is reset when the RST* Signal (Pin 19) is asserted low. 


Bits 0-5 This register is the high-order byte of the buffer memory address for vector 
process. 


Bits 6-7 RESERVED. 


74H — Vector Process Error Pattern (Read Only) 


This register is reset when the RST* Signal (Pin 19) is asserted low. 


Bits 0-7 This register is the error pattern for vector process. 
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8.8 77H — Sector Formatter Operation Control (Read/Write) 


This register is reset when the RST* Signal (Pin 19) is asserted low, or by a Sector Formatter 
Reset (Register 4FH, Bit 0). 


Bit O RESERVED. 
Bit 1 Data/Branch Field Mode Enable: When this bit is set, the Format 


Sequencer uses the Data/Branch Field (Register FFH) as a source for branch 
addresses instead of Bits 0-4 of the Branch Address (Register 78H). When this 
bit is reset, the Format Sequencer uses Bits 0-4 of the Branch Address Register 
(78H) as a source for branch addresses. This bit does not alter the address 
source for branch commands that use both the Branch Address (Register 78H) 


and the Data/Branch Field (Register FFH) for potential address sources. 


Bit 2 Suppress Transfer: When this bit is set, the buffer access mechanism of 
Data Transfer (Current Sequencer Word Control Field, Bit 0) is disabled. 
During a write operation, the NRZ Data Field will be written with the pattern of 
the Current Sequencer Word Data/Branch Field (Register FFH). During a read 
operation, the incoming NRZ Data will have CRC verified, but no data will be 
transferred to the buffer memory. 


Bit3 Buffer/Disk R/W* Transfer Direction: This bit indicates the direction of 
information transfer to/from the Sector Formatter when disk data transfer is 
initiated by the Sector Formatter. When this bit is reset, the data transfer 
direction is from the Sector Formatter to the buffer memory. When this bit is set, 
the data transfer direction is from the buffer memory to the Sector Formatter. 


Bit 4 Inhibit Data Field Carry: When this bit is set, the Format Sequencer Byte 
Counter carry normally used to trigger the next fetch of a Writable Control Store 
(WCS) Word will be inhibited. This bit will be automatically reset whenever a 
carry has occurred and the Sector Size (Register 4EH) has previously been 
decremented to zero. This bit can be both set and reset by the Format 
Sequencer branch commands. When the Format Sequencer is running, writes 
to this register must be synchronized with the Format Sequencer activities. 


Bit 5 Edge Detect Sensitivity Selection: This bit specifies which edge (rising or 
falling) triggers the SMDET edge detect circuit. This bit modifies the Format 
Sequencer branch logic, the Sector Detected (Register 7DH, Bit 0) logic. When 
this bit is reset, only rising edges will trigger the edge detect circuitry. When this 


bit is set, only falling edges will trigger the edge detect circuitry. | 
Bits 6-7 RESERVED. 
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This register is reset when the RST“ Signal (Pin 19) is asserted low, or by a Sector Formatter 
Reset (Register 4FH, Bit 0). 


Bits 0-4 Next Active Format Sequencer Address: Bits 0-4 provide the next 
Writable Control Store (WCS) address to be executed by the Format 
Sequencer. This address could read the contents of the Format Sequencer 
Start Address Register (79H), or the Branch Address Register (78H), or the 
Current Sequencer Word Next Address Field (Register 9FH) or the Data/Branch 


| Field (Register FFH). 


Bits 5-7 RESERVED. 


78H — Branch Address (Write) 


This register is reset when the RST“ Signal (Pin 19) is asserted low, or by a Sector Formatter 
Reset (Register 4FH, Bit 0). 


Bits 0-4 Branch Address: The Format Sequencer jumps to the address specified in 


these bits when a branch condition is programmed and met. 


Bits 5-7 RESERVED. 
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8.11 79H — Format Sequencer Status Register 1 (Read) 


This register is reset when the RST“ Signal (Pin 19) is asserted low, or by a Sector Formatter 
Reset (Register 4FH, Bit 0). 


Bit 0 Format Sequencer Active: This bit is set while the Format Sequencer is in 
an active processing state. 
Bit 1 AM Active: This bit is set when the Data Transfer Bit (Writable Control Store 


(WCS) Control Field, Bit 0) is reset and the Count/ Process AM Bit (Writable 
Control Store (WCS) Count Field, Bit 7) is set. It is reset after reading or writing 


of the ECC bytes. It is also reset when the Format Sequencer stops. 


Bit 2 Data Transfer: This bit is set during data transfers between the buffer 
memory and the disk, that is any time the Data Transfer Bit (Writable Control 
Store (WCS) Control Field, Bit 0) is set even if the Suppress Transfer Bit 
(Register 77H, Bit 2) is set. 


Bit 3 Branch Active: This bit is set when a branch condition is met. Reading this 
register resets this bit. 
Bit 4 Synchronization Detect Status: This bit is set during a disk Read 


operation when the internal serializer/deserializer has been synchronized with 
the NRZ Read Data (a match has been found between the NRZ Read Data and 
the preprogrammed sync character (ODH, 00001011B). This bit is reset on the 


falling (trailing) edge of the Read Gate Signal (Pin 25). 


Bit 5 Format Sequencer Input: This bit indicates the status of the IDF Signal (Pin 
31). 

Bit 6 Format Sequencer Output: This bit indicates the status of the Output Bit 
(Writable Control Store (WCS) Control Field, Bit 2). 

Bit 7 Byte Ready: When this bit is set, it indicates that the scheduled buffer memory 
access is completed, and that another scheduled buffer memory access may be 
started. 


8.12 79H — Format Sequencer Start Address (Write) 


This register is reset when the RST“ Signal (Pin 19) is asserted low, or by a Sector Formatter 
Reset (Register 4FH, Bit 0). 


Bits 0-4 Start Address: A write to this register starts the Format Sequencer at the 
address written to this register. 
Bits 5-7 RESERVED. 
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8.13 7AH — Format Sequencer Status Register 2 (Read Only) 


This register is reset when the RST“ Signal (Pin 19) is asserted low, or by a Sector Formatter 
Reset (Register 4FH, Bit 0), or by a Format Sequencer start (a write to the Format Sequencer 
Start Address Register (79H)). 


Bit 0 Compare Not Equal: This bit is set when the result of the compare operation 
is not equal. The comparison is performed between the NRZ Read Data and 
either the buffer memory data or the Data/Branch Field in the Current 
Sequencer Word on all bytes where comparison was enabled in the Compare 
Enable Bit (Writable Control Store (WCS) Control Field, Bit 1). Compare Equal 
is only valid after the Format Sequencer has completed processing the CRC 

Field. This status is reset upon a Format Sequencer start (Register 79H) ora 
format sequencer read operation. 


Bit 1 Compare Greater Than: This bit is set when the NRZ Read Data is greater 
than either the buffer memory data or the Data/Branch Field in the Current 
Sequencer Word on the first byte where comparison was enabled in the 
Compare Enable Bit (Writable Control Store (WCS) Control Field, Bit 1). 
Compare Greater Than is only valid after the Format Sequencer has completed 
processing the CRC Field. This status is reset upon a Format Sequencer start 
(Register 79H) or a format sequencer read operation. 


Bit 2 Compare Less Than: This bit is set when the NRZ Read Data is less than 
either the buffer memory data or the Data/Branch Field in the Current 
Sequencer Word on the first byte where comparison was enabled in the 
Compare Enable Bit (Writable Control Store (WCS) Control Field, Bit 1). 
Compare Less Than is only valid after the Format Sequencer has completed 
processing the CRC Field. This status is reset upon a Format Sequencer start 
(Register 79H) or a format sequencer read operation. 


Bit 3 Data Field CRC Error: This bit is set after the last CRC Bit is read if there is a 
non-zero CRC syndrome indicating a read error in a Data Field. The read error 
was generated in the read transmission from the companion CL-SM330 chip. 
This status is reset upon a format sequencer start (Register 79H) or the start of a 


Format Sequencer read or write operation. 


Bit 4 Synchronization Time-Out Error: This bit is set after a time-out occurs and 
read synchronization has not occurred. The timer limit is held in the 
Synchronization Byte-Count Limit (Register 70H). The timer is enabled in the 
Current Sequencer Word. 


Bit 5 RESERVED. 
Bit 6 Disk/Buffer Parity Error: This bit is set by a buffer parity error during a buffer 


read (disk data read by the Format Sequencer or the microcontroller) with the 


Buffer Memory Parity Enable Bit (Register 53H, Bit 3) set. 
Bit 7 RESERVED. | 
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8.14 7DH — Sector Formatter Interrupt (Read/Write Reset) 


This register is reset when the RST“ Signal (Pin 19) is asserted low, or by a Sector Formatter 
Reset (Register 4FH, Bit 0). Each bit must be reset by the microcontroller by writing a one to 
that bit, thus clearing interrupts (if enabled in Register 4FH, Bits 1 and 6, and Register 7EH), 
and receiving further updated status. 


Bit 0 SMDET Detected: This bit is set by the edge programmed by the Edge 
Detect Sensitivity Selection Bit (Register 77H, Bit 5) of the SMDET Signal (Pin 
18). 

Bit 1 Vector Transmission Error Detected: This bit is set upon the detection of 
a CRC error in an Error Correction Vector Packet. 

Bit 2 Input Detected: This bit is set by the edge programmed by the Edge Detect 
Sensitivity Bit.(Register 77, Bit 5) of the input Signal. 

Bit 3 Sequencer Stopped Detected: This bit is set by the Format Sequencer 
cycling to the stopped condition. 

Bit 4 Branch Active Detected: This bit is set by the Format Sequencer meeting a 
programmed branch or stop condition. 

Bit 5 Data Transfer Detected: This bit is set by the Format Sequencer executing 


a Current Sequencer Word with Bit 0 of the Writable Control Store (WCS) 
Control Field set. 


Bit 6 Sequencer Output Detected: This bit is set by the Format Sequencer 
executing a Current Sequencer Word with Bit 2 of the Writable Control Store 


(WCS) Control Field set. 


Bit 7 Vector Parity Error: This bit is set upon the detection of a parity error in the 
data read from buffer memory during the vector processing sequence. 
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8.15 7EH — Sector Formatter Interrupt Enable (Read/Write) 


8.16 


76 


This register is reset when the RST~ Signal (Pin 19) is asserted low, or by a Sector Formatter 
Reset (Register 4FH, Bit 0). 


Bit 0 SMDET Detected Enable: When this bit is set, it enables the DINT Signal 
(Pin 32) to be asserted low when the SMDET Detected Bit (Register 7DH, Bit 0) 
is set. 

Bit 1 Vector Transmission Error Detected Enable: When this bit is set, it 


enables the DINT Signal (Pin 32) to be asserted low when the Vector 


Transmission Error Detected Bit (Register 7DH, Bit 1) is set. 


Bit 2 Input Detected Enable: When this bit is set, it enables the DINT Signal (Pin 
32) to be asserted low when the Input Detected Bit (Register 7DH, Bit 2) is set. 
Bit 3 Sequencer Stopped Detected Enable: When this bit is set, it enables the 


DINT Signal (Pin 32) to be asserted low when the Sequencer Stopped 


Detected Bit (Register 7DH, Bit 3) is set. 


Bit 4 Branch Active Detected Enable: When this bit is set, it enables the DINT 
Signal (Pin 32) to be asserted low when the Branch Active Detected Bit 


(Register 7DH, Bit 4) is set. 


Bit 5 Data Transfer Detected Enable: When this bit is set, it enables the DINT 
Signal (Pin 32) to be asserted low when the Data Transfer Detected Bit 
(Register 7DH, Bit 5) is set. 


Bit 6 Sequencer Output Detected Enable: When this bit is set, it enables the 
DINT Signal (pin 32) to be asserted low when the Sequencer Output Detected 
Bit (Register 7DH, Bit 6) is set. 


Bit 7 Vector Parity Error Detected Enable: When this bit is set, it enables the 
DINT Signal (Pin 32) to be asserted low when the Vector Parity Error Detected 
Bit (Register 7DH, Bit 7) is set. 


7FH — Sector Formatter Stack (Read Only) 


This register has no initialization conditions. 


Bits 0-7 The first microcontroller read of this address after a Format Sequencer 
operation reads the last byte that was written (enabled by the Stack Enable Bit 
(Bit 4) of the Writable Control Store (WCS) Control Field) onto the stack. 


Each read of this address rotates the data in a ring fashion in the stack so the 
entire stack can be read. The data is read in LIFO (Last In, First Out) order. 


The stack is ten bytes deep. If more than ten bytes are written to the stack only 
the last ten bytes are saved. If more than ten bytes are read from the stack then 
the ten bytes of data are read continuously in a circular manner. 
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9.0 WRITABLE CONTROL STORE (WCS) FIELD DESCRIPTIONS 
9.1 S80H-9EH — Next Address Field (Read/Write) 


The Writable Control Store (WCS) has no initialization conditions. 


BITS[7:5] 000 = USE NEXT ADDRESS. 

001 = STOP ON CAC ERROR, OTHERWISE USE NEXT ADDRESS. 

010 = STOP ON COMPARISON NOT EQUAL, 
OTHERWISE USE NEXT ADDRESS. 

011 = STOP ON COMPARISON NOT EQUAL OR CRC ERROR, 

AND ((CRC = 1) AND (RG = 1)) OTHERWISE USE NEXT ADDRESS. 

100 » USE BRANCH ADDRESS ON GOOD CRC AND 
COMPARISON EQUAL, OTHERWISE USE NEXT ADDRESS. 

101 = USE BRANCH ADDRESS ON CAC ERROR, OTHERWISE USE NEXT ADDRESS. 


110 « USE BRANCH ADDRESS ON COMPARISON NOT EQUAL, 
CONTROL OTHERWISE USE NEXT ADDRESS. 
FIELD, BIT7 «0 111= USE BRANCH ADDRESS ON COMPARISON NOT 


EQUAL OR CRC ERROR, OTHERWISE USE NEXT ADDRESS. 


000 = USE NEXT ADDRESS. 
001 = STOP IF INPUT IS ASSERTED, OTHERWISE USE NEXT ADDRESS. 
010 = STOP IF SECTOR IS ASSERTED, OTHERWISE USE NEXT ADDRESS. 
011 = STOP ON COMPARISON NOT EQUAL, OTHERWISE USE NEXT ADDRESS. 
AND ((CRC = 0) OR (RG = 0)) 100 = USE BRANCH ADDRESS. 
101 = USE BRANCH ADDRESS ON INPUT ASSERTED, OTHERWISE USE NEXT ADDRESS. 
110 = USE BRANCH ADDRESS ON SECTOR ASSERTED, OTHERWISE USE NEXT ADDRESS. 
111 = USE BRANCH ADDRESS ON COMPARISON EQUAL, OTHERWISE USE NEXT ADDRESS. 


000= RESERVED. 
001= USE NEXT ADDRESS AND SET THE INHIBIT DATA FIELD CARRY BIT. 
010= RESERVED. 
O11= RESERVED. 
100= RESERVED. 
101 = STOP ON CRC ERROR. 

AND ((CRC = 1) AND (RG = 1)) USE BRANCH ADDRESS ON COMPARISON NOT EQUAL AND GOOD CRC. 

USE NEXT ADDRESS ON COMPARISON EQUAL AND GOOD CRC 


110 = STOP ON CRC ERROR. 
USE NEXT ADDRESS ON COMPARISON NOT EQUAL AND GOOD CRC. 
USE BRANCH ADDRESS ON COMPARISON EQUAL AND GOOD CRC, 


ff CONTROL 111= USE BRANCH ADDRESS ON CRC ERROR OR COMPARISON NOT EQUAL. 
FIELD, BIT7=1 USE NEXT ADDRESS ON COMPARISON EQUAL AND GOOD CRC. 


000 = RESERVED. 

001 = STOP IF DISK BUFFER PARITY ERROR OCCURRED, OTHERWISE USE NEXT ADDRESS, 
AND SET THE INHIBIT DATA FIELD CARRY BIT. 

010 = STOP IF SECTOR NOT ASSERTED, OTHERWISE USE NEXT ADDRESS. 

011= START SYNCHRONIZATION TIMER, USE NEXT ADDRESS ON RISING EDGE OF INPUT. 

AND ((CRC = 0) OR (RG =0)) USE BRANCH ADDRESS ON SYNCHRONIZATION TIME-OUT ERROR. 

100 = USE BRANCH ADDRESS ON SYNCHRONIZATION TIME-OUT ERROR, OTHERWISE USE 
NEXT ADDRESS. 

101 = USE BRANCH ADDRESS IF DISK BUFFER PARITY ERROR OCCURRED, OTHERWISE 
USE NEXT ADDRESS. 

110 = USE BRANCH ADDRESS IF SECTOR IS NOT ASSERTED, OTHERWISE USE NEXT ADDRESS. 

111= RESERVED. 
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9.1 80H-9EH — Next Address Field (Read/Write) (cont.) 


Bits 0-4 Next Address: This is the address the Format Sequencer will go to after the 
down counter for the Count Field has reached zero and a branch has not been 
taken. There are 31 possible next address locations (OOH-1EH). Fetching 


address 1FH stops the Format sequencer. 


Bits 5-7 Branch Command: All branch commands are evaluated at the end of 
execution of the Current Sequencer Word. 
NOTE: The Branch Address can be the Branch Address Register (78H) or the 
Data/Branch Field unless otherwise explicitly stated. 


Branch commands when the Alternate Branch Command Select Bit (Bit 7) of the 
Writable Control Store (WCS) Control Field is reset and all of the following 
conditions are true: 

¢ the Process CRC Bit (Bit 6) of the Writable Control Store (WCS) Count Field is set and 


¢ the Read Gate Signal (Pin 25) is asserted: 
000= Use the Next Address Field. 
001= Stop on CRC error, otherwise use the Next Address Field. 


010= Stop on comparison not equal, otherwise use the Next Address Field. 
011= Stop oncomparison not equal or CRC error, otherwise use the Next Address Field. 
100= Use the branch Address on good CRC and comparison equal, otherwise use the Next 


Address Field. 
101= Use the branch Address on CRC error, otherwise use the Next Address Field. 
110= Use the Branch Address on comparison not equal, otherwise use the Next Address Field. 


111= Use the Branch Address on comparison not equal or CRC error, otherwise use the Next 
Address Field. 


Branch commands when the Alternate Branch Command Select Bit (Bit 7) of the 
Writable Control Store (WCS) Control Field is reset and any of the following 
conditions are true: 

* the Process CRC Bit (Bit 6) of the Writable Control Store (WCS) Count Field is reset or 


« the Read Gate Signal (Pin 25) is deasserted: 

000= Use the Next Address Field. 

001= Stop if the IDF Signal (Pin 31) is asserted, otherwise use the Next Address Field. 
010= Stop if the SMDET Signal (Pin 18) is asserted, otherwise use the Next Address Field. 
011= Stopon comparison not equal, otherwise use the Next Address Field. 

100= Use the branch address. 


101 = Use the branch address when the IDF Signal (Pin 31) is asserted, otherwise use the Next 
Address Field. 
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9.1 80H-9EH — Next Address Field (Read/Write) (cont.) 


Bits 5-7 (cont.) 110 = Use the Branch Address when the SMDET Signal (Pin 18) is asserted, otherwise use the 
next Address Field. 


111= Use the Branch Address on comparison equal, otherwise use the Next Address Field. 


Branch Commands when the Alternate Branch Command Select Bit (Bit 7) of 
the Writable Control Store (WCS) Control Field is set and all of the following 


conditions are true: 
¢ the Process CRC Bit (Bit 6) of the Writable Control Store (WCS) Count Field is set and 


« the Read Gate Signal (Pin 25) is asserted: 
000= RESERVED. 
001= Use the Next Address Field and set the Inhibit Data Field Carry Bit(Register 77H, Bit 4). 
010= RESERVED. 
011= RESERVED. 
100= RESERVED. 
101= Stopon CRC error. 
Use the Branch Address on comparison not equal, and good CRC. 
Use the next Address Field on comparison equal and good CRC. 
110= Stopon CRC error. 
Use the next Address Field on comparison not equal and good CRC. 
Use the Branch address on comparison equal and good CRC. 
111= Use the Branch Address on CRC error or comparison not equal. 
Use the Next Address Field on comparison equal and good CRC. 


Branch commands when the Alternate Branch Command Select Bit (Bit 7) of the 
Writable Control Store (WCS) Control Field is set and any of the following 


conditions are true: 
¢ the Process CRC Bit (Bit 6) of the Writable Control Store (WCS) Count Field is reset or 


¢ the Read Gate Signal (Pin 25) is deasserted: 
000= RESERVED. 


001= Stop if disk buffer parity error occurred, otherwise use the next Address Field and set the 
Inhibit Data Field Carry Bit (Register 77H, Bit 4). 


010= Stop if the SMDET Signal (Pin 18) is asserted, otherwise use the next Address Field. 
011= Start the synchronization timer, use the Next Address Field on the rising edge of IDF 
Signal (Pin 31). 
Use the branch address if the Synchronization Time-Out Error Bit (Register 7DH, Bit 4) is 
set. 


100= Use the branch address if the Synchronization Time-Out Error Bit (Register 7DH, Bit 4) is 
set, otherwise use the next Address Field. 


101= Use the Branch Address if a disk buffer parity error occurred, otherwise use the next 
Address Field. 


110= Use the branch address if the SMDET Signal (Pin 18) are deasserted, otherwise use the 
next Address Field. 


111= RESERVED. 
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AOH-BEH — Control Field (Read/Write) 


The WCS has no initialization conditions. 


Bit 0 Data Transfer: When this bit is set, the Count Field is used as an eight-bit 
counter. Each byte cycle that this bit is set, a byte of data will be accessed for 
the serializer/deserializer from the buffer memory if the Suppress Transfer Bit 
(Register 77H, Bit 2) is reset, or from the Writable Control Store (WCS) 
Data/Branch Field if the Suppress Transfer Bit (Register 77H, Bit 2) is set. If the 
Write Gate Signal (Pin 26) is asserted then a byte of data is read from the 
appropriate source. If the Read Gate signal (Pin 25) is asserted then a byte of 
data is written to the buffer memory (if the Suppress Transfer Bit (Register 77H, 


Bit 2) is reset). 


Bit 1 Compare Enable: Each byte cycle that this bit is set and the Read Gate 
Signal (Pin 25) is asserted then the deserialized NRZ Read Data will be 
compared against the Writable Control Store (WCS) Data/Branch Field or 
against the buffer memory data if a sector Data Field verify operation has been 


programmed. 


Bit 2 Output: This bit is connected to the Output Signal (Pin 30) and can be used to 
synchronize the external circuitry or the microcontroller (through the internal 


interrupt circuitry, see Register 7DH, Bit 6). 


Bit 3 Invalid NRZ Control: When this bit is set and the Read Gate Signal (Pin 25) 
is asserted, the NRZ Read Data synchronization circuit is prevented from 
Starting. 

Bit 4 Stack Enable: When this bit is set, read data is pushed onto the ten-byte 


recirculating stack. 
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9.2 AQH-BEH — Control Field (Read/Write) (cont.) 


Bits 5-6 


Bit 7 
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Control! Field: Bits 5-6 are encoded as follows: 
Encoded Control Field Bits 5-6 


Control Field 
Bit 5 CODED AS 


0 No Change 

1 Write Gate-On 
0 Read Gate-On 
1 Write Gate-Off 


DESCRIPTION 


The state of the Write Gate Signal (Pin 26) and the Read Gate 
Signal (Pin 25) is not affected. 


This code is used to assert the Write Gate Signal (Pin 26). The 
Write Gate Signal (Pin 26) is asserted during the first count of 
the execution of the Format Sequencer word with this bit 
combination set. The Write Gate Signal (Pin 26) is not 
asserted if the Read Gate Signal (Pin 25) is asserted when this 
bit combination is executed. 


This code is used to assert the Read Gate Signal (Pin 25). The 
Read Gate Signal (Pin 25) is asserted during the first count of 
the execution of the Format Sequencer word with this bit 
combination set. The Read Gate Signal (Pin 25) is not 
asserted if the Write Gate Signal (Pin 26) is asserted when this 
bit combination is executed. The Read Gate Signal (Pin 25) is 
deasserted at the end of CRC processing, or when the Format 
Sequencer goes to the stopped state. 


This code is used to deassert the Write Gate Signal (Pin 26). 
The Write Gate Signal (Pin 26) is cleared during the last count 
of the execution of the Format Sequencer word with this bit 
combination set. The Write Gate Signal (Pin 26) is also 
deasserted when the Format Sequencer comes to the stop 
State. 


Alternate Branch Command Select: When this bit is set, the branch 
conditions in the Next Address Field are redefined as described in Section 9.1). 
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9.3 COH-DEH — Count Field (Read/Write) 


This is the Count Field of the Writable Control Store (WCS) word. This sets the initial value of the 
Sequencer Counter when a new state is entered. The WCS has no initialization conditions. 


COUNT/PROCESS CRC/START SYNCHRONIZATION TIMER 
COUNT/PROCESS AM 


Bits 0-5 Count: These bits are always used for the initial value of the low-order bits of 
the Format Sequencer Byte Counter for the execution of the Current Sequencer 
Word. The counter is decremented each byte time. When it reaches zero, a 
new Format Sequencer word will be fetched from the Writable Control Store 
(WCS). The byte counter is used in three modes of operation where unused 
bits are used as special control bits. 


Bit 6 Count/Process CRC/Start Synchronization Timer: This bit is used for 
three functions. 


Count: In this mode, this bit is used for the initial value of the Format 
Sequencer Byte Counter for the execution of the Current Sequencer Word. 
This mode is selected when the Data Transfer Bit (Bit O of the Writable Control 
Store (WCS) Control Field) is set. 


Process CRC: When this bit is set, the Format Sequencer will process the 
current NRZ Data as the CRC Field. In a write operation, the generated 
remainder is appended to the outgoing NRZ Data stream. In a read operation, 
the circuit is set up to evaluate the recomputed remainder for a zero syndrome. 
This mode is selected when the Data Transfer Bit (Bit 0 of the Writable Control 
Store (WCS) Control Field) is reset, and the Read Gate-On Bit code is not set. 


Start Synchronization Timer: In this mode, this bit is used to reset and start 
the Synchronization Timer. This counter is used to limit the amount of time that 
the Format Sequencer will wait for synchronization with the NRZ Read Data. 
The Synchronization Byte-Count Limit (Register 70H) holds a limit for the 
counter. If the count limit is exhausted, the current read operation will be 
aborted (the Format Sequencer stopped) and the Synchronization Time-Out 
Error Bit (Register 7AH, Bit 4) will be set. This mode is selected when the Read 
Gate-On Bit code (Bit 5 reset and Bit 6 set of the Writable Control Store (WCS) 
Control Field) is set, and the Data Transfer Bit (Bit 0 of the Writable Control 
Store (WCS) Control Field) is reset. 
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9.3 COH-DEH — Count Field (Read/Write) (cont.) 


Bit 7 


Count/Process AM: This bit is used for two functions. 


Count: In this mode, this bit is used for the initial value of the Format 
Sequencer Byte Counter for the execution of the Current Sequencer Word. 
This mode is selected when the Data Transfer Bit (Bit 0 of the Writable Control 
Store (WCS) Control Field) is set. 

Process AM: When this bit is set, the AM Active Bit (Register 79H, Bit 1) will 
be set. This mode is selected when the Data Transfer Bit (Bit 0 of the Writable 
Control Store (WCS) Control Field) is reset. 


9.4 EQH-FEH — Data/Branch Field (Read/Write) 


Bits 0-7 


This field has two functions. 


In any mode, the Data/Branch Field is used for data. This register is the source 
for all overhead bytes (bytes without the Data Transfer Bit (Control Field, Bit 0) 
set) of data used by the device during write operations. During read operations, 
it is one of the operands to the comparison logic. When the Data Transfer Bit 
(Control Field, Bit 0) is set with the Write Gate Signal (Pin 44) asserted, the 
source for write data will be the external buffer. When the Suppress Transfer Bit 
(Register 77H, Bit 2) is set with the Write Gate Signal (Pin 26) asserted, the 
source for Write Data will be the contents of this register. 


When the Data/Branch Field Enable Bit (Register 77H, Bit 1) is set, Bits 0-4 will 
be used as the branch address if a branch command is programmed and the 
condition is met. 

NOTE: This option provides the Format Sequencer programmer with an extremely 
flexible branch addressing option. However, if a branch command is 
programmed in the same Format Sequencer word that uses the Writable 
Control Store (WCS) Data/Branch Field then the contents of this field must be 
appropriate for both uses. This dual use is improbable, and the problem should 
be avoided. 
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10.0 SEQUENCER REGISTER DESCRIPTIONS 
These registers contain the value of the currently executing Writable Control Store (WCS) word. 
10.1 9FH — Current Sequencer Word — Next Address Field (Read/Write) 


This register is set when the RST* Signal (Pin 19) is asserted low, or by a Sector Formatter Reset 
(Register 4FH, Bit 0). 


10.2 BFH — Current Sequencer Word — Control Field (Read/Write) 


This register is reset when the RST* Signal (Pin 19) is asserted low, or by a Sector Formatter Reset 
(Register 4FH, Bit 0). 


10.3 DFH — Current Sequencer Word — Count Field (Read/Write) 


This register is reset when the RST* Signal (Pin 19) is asserted low, or by a Sector Formatter Reset 
(Register 4FH, Bit 0). 


10.4 FFH — Current Sequencer Word — Data/Branch Field (Read/Write) 


This register is reset when the RST* Signal (Pin 19) is asserted low, or by a Sector Formatter Reset 
(Register 4FH, Bit 0). 
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11 ELECTRICAL SPECIFICATION 
11.1 Absolute Maximum Ratings 
Ambient Temperature Under Bias...................006 0° C to 70°C 
Storage TEMpPerature ...........cccssessesccseecssceresceeseees - 65° C to 150° C 
Voltage On Any Pin With Respect To Ground.... GND - 0.5 to Vcc + 0.5 Volts 
Power Dissipation..................ccssccccssssescsessneeessseeesens 0.500 Watt 
Power Supply Voltage ............cccssesssssseesesseeeseees 7 Volts 
NOTE: 
Stresses above those listed under absolute maximum ratings may cause permanent damage to the 
device. This is a stress rating only and functional operation of the device at these or any conditions above 
those indicated in the operational sections of this specification is not implied. Exposure to absolute 
maximum rating conditions for extended periods may affect device reliability. 
11.2 DC Characteristics 


SYMBOL PARAMETER MIN MAX UNITS CONDITIONS 
Vcc Power Supply Voltage 4.75 5.25 Vdc Operating 

VIL Input Low Voltage 05 0.8 Vdc 

VIH Input High Voltage 2.0 Veco +0.5 Vdc 

VoL!:3 Output Low Voltage 0.4 Vde loL=2mA 
VoL? Output Low Voltage 0.5 Vdc lo. = 48 mA 
Von! Output High Voltage 2.4 Vdc loH = -400 pA 
lec Supply Current 50 mA Operating 

IL Input Leakage -10 10 yA 0< Vin < Vcc 
VOL I/O Leakage Current -10 10 LA 0<Vin< Vcc 
CIN Input Capacitance 10 pF 

COUT Output Capacitance 10 pF 

NOTES: 


1) All output pins except for the SCSI bus signals. 

2) All SCSI bus output or I/O signals. 

3) lo~ = 4 mA for the READ GATE signal (Pin 43) and the WRITE GATE signal (Pin 44). 
4) All unused inputs must be tied to the inactive state to GND or Vcc appropriately. 
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11.3 AC Characteristics 


Unless otherwise specified the following timings are operating under the assumption that all 
non-SCSI outputs will drive one Schottky TTL load in parallel with 50 pF and all inputs are at 
TTL level. The MIN and MAX timings are conforming to the operating ranges of power supply 
voltage of 5V +/-5% and ambient temperature of 0° C to 70° C. The rise and fall times for clock 
signals should be kept at or below 15% of the clock period. 


11.3.1 RESET Assertion Timing Parameters 


SYMBOL PARAMETER MIN MAX UNITS 
tRPWL RST* pulse width low 500 ns 


11.3.1.1 RESET Assertion Timing 


svsx/~ \_ J \_J/™\_S \S \_ 


- tRPWL ; 
* a 
RST : : 
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11.3.2 Microcontroller Interface Timing Parameters 


SYMBOL PARAMETER MIN MAX _ UNITS 
tA ALE width 20 ns 
tAW Address valid to WR* J or DS T 30 ns 
tAR Address valid to RD* J or DS T 20 ns 
tw WR’ width 120 ns 
tR RD* width 120 ns 
AS Address valid to ALE J 5 ns 
AH ALE J to address invalid 12 ns 
cs CST to RD’ WR‘ or DST 20 ns 
CH RD’ 1, wR’ T or DSL to CS J 5 ns 
WDS Write data valid to WR’ T ortoDS J 55 ns 
WDH WR’ T or DS J to Write data invalid 10 ns 
tDA RD" J or DS T to Read data valid 100 ns 
tDH RD* T or DS J to Read datainvalid 10 ns 
tDZ RD* T or DS J to Read data undriven 50 ns 
tDS DS width 120 ns 
tDRDY ALE J to READY valid 40 ns 
tSRW R/W" valid to DS T 30 ns 
tHRW DS 1 to RM" invalid 20 ns 
NOTES: 


1) T dicates rising edge. J indicates falling edge. 

2) When the I/MC* signal (Pin 24) is asserted high, the Intel bus control interface is selected. The timing 
diagram in Sections 11.3.2.1 and 11.3.2.3 depict a register read and write respectively with this 
interface selected. 

3) When the I/MC* signal (Pin 24) is deasserted low, the Motorola bus control interface is selected. The 
timing diagrams in Section 11.3.2.2 and 11.3.2.4 depict a register read and write respectively with this 
interface selected. 
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11.3.2.1 Register Read Operation in Intel Mode (AC2) 


ALE 


AS: AH: . 1DH . 


RD* i 


READY ——_——_P- 
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11.3.2.2 Register Read Operation In Motorola Mode (AC3) 


tA 


ALE 
AS : AH. {DH | 
ADO:7 a ee a“ 
: - tAR. : : 
CcS* : = z : 


READY _———— 
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SetetetatetetetetetstetetnteteteTatetatetatatetetetetetatetatatetatatatetetatetetetstetetetetststateletetetetetetetatetetatatetetetetetatstatstetetetetetetatetstatatetatetetetretet tte 


slelelateteceteretetetetateteteretetecetetetetatetetatotatetateretetatetetetateterataretatetatetetetatetetetatetatstatetetatetetetatetetateteletetetetatetatetateratatetetetatataretetetats 
sieetsscesotecesecesssecssecsseneseatstetaretaceterercnesensestesssseasetecessestessrecnesensststeneteteaetetesetatenetetetosetenrtetatstotetstetstetetstetetetetetatetetetereistetstetatets 
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11.3.2.3 Register Write Operation in Intel Mode (AC4) 


ALE 
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11.3.2.4 Register Write Operation in Motorola Mode (AC5) 


: tA : 
—__——_—_—_————————— >: 


SRW OR AE HRW 
READY 


__tDRDY_, \ / 
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11.3.3 Disk Read/Write Timing Parameters 
SYMBOL PARAMETER MIN MAX UNITS 
t RRCLK period 41 ns 
t/2 RRCLK high/low time 16 ns 
DS NRZ in valid to RRCLK T 10 ns 
DH RRCLK T to NRZ in invalid 5 ns 
DV RRCLKT to NRZ out 10 25 ns 
NOTES: 
1) T indicates rising edge. 
2) J indicates falling edge. 
11.3.3.1 Disk Read Timing (AC7) 
: t 4 
AML ____________ i 
<_____>-: 
v2 : 
<< Ve >: : 


(Read) : : . 
<<: DH 
DS - 


11.3.3.2 Disk Write Timing (AC8) 


RRCLK 


a i! DV 


NRZ DATA 
(Write) = ott arias 4 | > —— 
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11.3.4 Buffer Memory Read/Write Timing Parameters 


SYMBOL PARAMETER MIN MAX UNITS 
t SYSCLK period 40 ns 
2 SYSCLK high/low time 16 ns 
tAV SYSCLK T to address valid 30 ns 
tMV SYSCLK J to MOE’ JL 30 ns 
tMH SYSCLK J to MOE" T 30 ns 
tWwV SYSCLK J to WE" 1 30 ns 
tWH SYSCLK J to WE’ T 30 ns 
tDOV SYSCLK T to data out valid 40 ns 
tDOH SYSCLK T to data out invalid 0 ns 
tDIS Data in valid to SYSCLK J 5 ns 
tDIH SYSCLK J to data in invalid 20 ns 
tRV SYSCLK J to RAS’ 1 30 ns 
tRH SYSCLK J to RAS’ T 30 ns 
tRAV SYSCLK T to row address valid 30 ns 
tRAH SYSCLK T to row address invalid 30 ns 
tCV SYSCLK J to CAS’ 1 | 30 ns 
tCH SYSCLK J to CAS’ T 30 ns 
tCAV SYSCLK T to column address valid 30 ns 
tCAH CAS’ | to column address invalid (2) 

NOTES: 


1) T indicates rising edge. J indicates falling edge. 
2) Column address remains valid throughout CAS" low time. 
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11.3.4.1 SRAM Read Timing (AC10) 


tWBA 


CL-SM331 
SCSI Optical Disk Controller 


NOTE: 


tWBA is a functional parameter that gives the duration of one RAM data buffer access cycle in SYSCLK 
periods. The value is programmed in Bits 1-0 of Register 54H. These examples show tWBA = 4t. 
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Setetetesetetetatelotetererereteleteteretererateretetereretersterererereterererererererstorsterpiotetersreroreretataterererererstorereceteresececstereraterecereretetetetetetetetatatetatete 


11.3.4.3 Normal DRAM Read, Write, and Refresh Cycles (AC12) 


96 


t v2 -t2 - 
—— Pe SP: 


MOE* 


4WRH 


tCVpe we pe ICH: 


BA17/CAS* eS WAL 


: > tCAV : : =f ms ; 
fa 2 : tRAH . : a : ae a saa 
TRAV: <_< —— - —p- ~<eIRAV Sag ss tRAH>- ~<«- 


Columin Add Row Add Column Add Refresh Address 


(DIS? eeetDIH = eee tD0V 0m: DOH 


EWN fe QS EEN XQ 


NOTES: 


1) 


4) 


tWRL and tWRH are functional parameters that specify the duration of the BA16/RAS* signal (Pin 14) 
width low and the BA16/RAS* signal (Pin 14) width high (in SYSCLK periods) for a normal RAM data 
buffer access cycle. These values are programmed in Bits 3 - 0 of Register 54H. This example shows 
values of tWRL=2 and tWRH=1. 

The BA17/CAS’ signal (Pin 5) is asserted low one SYSCLK cycle after the BA16/RAS: signal (Pin 14) 
is asserted low. The BA17/CAS signal (Pin 5) is deasserted high when the BA16/RAS* signal (Pin 
14) is deasserted high. 

The MOE’ signal (Pin 15) is asserted low and deasserted high along with the BA17/CAS" signal (Pin 
5) in a Read access. The MOE signal (Pin 15) is deasserted high throughout Write and Refresh 
cycles. 

A Write cycle is always an early Write cycle. The WE’ signal (Pin 16) is asserted low and deasserted 
high along with the BA16/RAS signal (Pin 14). Data out is valid by the falling (leading) edge of the 
BA17/CAS signal (Pin 5) and is held valid while the BA17/CAS signal (Pin 5) is asserted low. 
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BA16/RAS’ 


BA17/CAS' 


tWAL-T = tWCH :  tWCL = tWCH =:  tWCL:  tWCH — :~ tWCL 
<q—__ >_>: 


WE* 


BAO:11 Row Add Column Add 1 Column Add 2 Column Add 3 Column Add 4 Row Add 
~YNN 
M0, 


BDO:7, BDP 
NOTES: 


oN 
1) tWRL = 2, tWRH = 1, tWCL = 1, tWCH = 1. 
2) This is only a functional timing diagram and does not depict AC-tested parameters. 
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BSS IIIS SOS IOS DOGS 5 SD OO 00 


11.3.4.5 Page Mode DRAM Write Cycle (ACB4) 


BA16/RAS* 


BA17/CAS" 


>: tWRL-T : tWCH : tWCL :  tWCH =: tWCL : tWCH :~ tWCL 


MOE* 


BAO:114 Row Add Column Add 1 Column Add 2 Column Add 3 Column Add 4 Row Add 


NOTES: 
1) tWRL= 2, tWRH = 1, tWCL = 1, (WCH = 1. 
2) This is only a functional timing diagram and does not depict AC-tested parameters. 
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11.3.5 SCSI Arbitration Timing Parameters 


SYMBOL PARAMETER MIN MAX UNITS 
tBAA BSY’* and SDB(n)* assertion delay from 

bus free detected 7ts + 40TT ns 
tBAD Bus abritration assertion or deassertion delay 12ts + 40TT ns 
NOTES: 


tT The CL-SH350 SCSI ID signal asserted on the SCS! data bus for arbitration. 
tt ts is the SCSI clock period, a function of SYSCLK as defined in Register 44H/64H, Bits 5-7. 


11.3.5.1 SCSI Arbitration Timing (ACB6) 


BSY*\\7. \ / 
: tBAA : 
ae ate 


NOTE: 
This is only a functional timing diagram and does not depict AC-tested parameters. 
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11.3.6 SCSI Select/Reselect Timing 

11.3.6.1 SCSI Selection Timing Parameters 
SYMBOL PARAMETER MIN MAX UNITS 
tSBS SCSI bus SELECTION data assertion 6ts + 40T ns 
tBN SCSI BSY* deasserted high 2ts + 40T ns 


NOTE: 
T ts is the SCSI clock period, a function of SYSCLK as defined in Register 44H/64H, Bits 5-7. 


11.3.6.2 SCSI Selection Timing (ACB8) 


BSY* } 
: {BN ; 
SEL* 


SDBP*,SDBO0*:7* < 


- tSBS ae: 
AIN* 
NOTE: 


This is only a functional timing diagram and does not depict AC-tested parameters. 
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11.3.6.3 SCSI Reselection Timing Parameters 


SYMBOL PARAMETER MIN MAX UNITS 
tSBR SCSI bus RESELECTION data assertion 6ts + 40t ns 
{BN SCSI BSY* deasserted high 2ts + 40T ns 
NOTE: 


tT ts is the SCSI clock period, a function of SYSCLK as defined in Register 44H/64H, Bits 5-7. 


11.3.6.4 SCSI Reselection Timing (ACB10) 


BSY* / 
—<]——___ >: 
{BN 
SEL* 


SDBP*,SDBO*:7* x 


: 4 tSBR . : 
I*/O : 
NOTE: 


This is only a functional timing diagram and does not depict AC-tested parameters. 
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11.3.7 Target Mode Asynchronous Data Transfers 
11.3.7.1 Data Out Phase Timing Parameters 
SYMBOL PARAMETER MIN MAX UNITS 
tALRH ACK’ J to REQ’ T 55 ns 
tALRL ACK’ J to REQ’ J 2T +55 ns 
if tALAH < 2T 
tALAH + 55 ns 
if tALAH > 2T 
tDS SDBO':7", SDBP’ setup to ACK’ J 40 ns 
tDH SDBO0":7", SDBP" hold from REQ’ T 0 ns 


11.3.7.2 Data Out Phase Timing (AC15) 


> tALRH : 
REQ* <j} : : 
hag ALAR : 
ACK" : : | 7 


102 SE TE TERE TE DN MT IST TTT April 1991 


CL-SM331 SS 
SCSI Optical Disk Controller = CIRRUS LOGIC 


11.3.7.3 Data In Phase Timing Parameters 


SYMBOL PARAMETER MIN MAX UNITS 
tALRH ACK’ J to REQ" T 55 ns 
tALRL ACK’ J to REQ’ J 3T (4t)t+ 55 ns 
if tALAH < 3t (4t) 
tALAH + 55 ns 
if tALAH > 3t (4t) 
tSRL SYSCLK T to REQ’ J 70tt ns 
tSADV SYSCLK T to SDBO":7", SDBP” valid delay 60 ns 
tALDH SDBO0’:7", SDBP" hold from ACK’ J t-10 ns 
NOTES: 


T This time is 3t if the SCSI DATA SET UP SELECT bit (Register 51H, Bit 5) is reset or the 
time is 4t if the SCSI DATA SET UP SELECT bit is set. 
TT For reference only, tSRL and tSADV together gaurantee a data setup time of 55ns. 


11.3.7.4 Data In Phase Timing (AC17) 


SYSCLK | 


REQ" {SRL : 0 ee ee TALRH 
aaa *  tALRL 
: ij 
' 3 ‘<¢__ p>: 
ee: ~<-1SADV fe? tALDH 


SDBO0*:7*, SDBP* x x 
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11.3.8 Initiator Mode Asynchronous Data Transfers 
11.3.8.1 Data In Phase Timing Parameters 
SYMBOL PARAMETER MIN MAX UNITS 
tRLAL REQ" J to ACK’ J 55 ns 
tRHAH REQ" T to ACK’ T 2t +55 ns 
if tRLRH < 2t 
tRLRH + 55 ns 
if tRLRH > 2t 
tDS SDBO0":7", SDBP* setup to REQ” 1 40 ns 
tDH SDB0’:7", SDBP* hold from ACK’ J 0 ns 
Sar arora enaeeeneeeeeeanenaaaanemaaaneaentaeteetctoeeentanreseaennsnrsteneenerenesmanneameesnemeRannaaneeeaanesannansetsaneaeneanSaEanwecteytaaaaneennnaeree saan ea enTonetaanao=eSaSiseSaaasncasoneaeheesistGaoneasaasenesseSaoyeanaensnsne=sseeaNeasseacensesn=eeyennansnas=oeeaeaseeeeenat==e—ererecan=eremerreeeseeeseas 
11.3.8.2 Data In Phase Timing (AC19) 
; tRLRH ; 
Ce 
REQ* :; 
ACK* 


tRHAH 
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11.3.8.3 Data Out Phase Timing Parameters 


SYMBOL PARAMETER MIN MAX UNITS 
tRHAH REQ’ T to ACK’ T 55 ns 
tRHAL REQ’ T to ACK’ L 3t (4t)T + 55 ns 
if (RHRL < 3t 
tRHRL + 55 ns 
if tRHRL > 3t 
tSAL SYSCLK T to ACK’ J 75tt ns 
tSADV SYSCLK T to SDBO0":7*, SDBP" valid delay 55 ns 
tRHDH SDB0":7", SDBP” hold from REQ’ T 0 ns 
NOTES: 


t This time is 3t if the SCS| DATA SET UP SELECT bit (Register 51H, Bit 5) is reset or the 
time is 4t if the SCS! DATA SET UP SELECT bit is set. 
tt For reference only, tSAL and tSADV together guarantee a data setup time of 55 ns. 


11.3.8.4 Data Out Phase Timing (AC21) 


_tRHRL gs 


REQ* 


(RHAL 
‘<?§_ >: 
tSAL 2 ee —RHAH SC; 


ACK* 


>  t_ tSADV ‘| RHDH 


SDBO0*:7*, SDBP* 4 x 
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11.3.9 Target Mode Synchronous Data Transfers 
11.3.9.1 Data Out Phase Timing Parameters 
SYMBOL PARAMETER MIN MAX UNITS 
tSDAS SDBO":7", SDBP” set-up time to ACK’ | 40 ns 
tSDAH ACK’ J to SDBO":7", SDBP* hold time 100 ns 
11.3.9.2 Data Out Phase Timing (AC23) 
ACK* 
tSDAS : | tSDAH 
-——___—$ $$$ > <P: 
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11.3.9.3 Data In Phase Timing Parameters 


SYMBOL PARAMETER MIN MAX UNITS 
1SRRF —sSYSCLKT toREQ’ldelay = = ©)—0 - 45—i—i“(é(cSTCO*;” 
1SRRR_—SSYSCLKT toREQ’T delay =———“‘i‘(< ;3OW#*;‘i‘<;zxz HS !”””CU! 
1SFRR—sSYSCLKItoREQ’T delay ——“C—CC—C—SH_ CC ( ”:”:~—tiS™” 
tSDV SYSCLK T to SDBO":7", SDBP’ valid delay 55 ns 
NOTE: 


For the Data In phase, the SCSI data bus set-up and hold times in synchronous transfer mode 
are dependent on the SYSCLK period t, in ns, and the value P which sets the synchronous 
transfer rate in Register 43H/63H, Bits 4-7. 


If P is chosen as an even number then: 


SDBO0":7", SDBP’ set-up time to REQ’ = = » (t-15) 
SDBO0":7", SDBP" hold time from REQ’ J = P .(t5) 
If P is chosen as an odd number then: ; 
SDBO0":7", SDBP” set-up time to REQ’ 1 = = » (t-15) 
SDBO0":7", SDBP” hold time from REQ’ 1 = (t-5) 
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11.3.9.4 Data In Phase Timing (AC26) 


Even Number of SYSCLK Cycles per SCS] Synchronous Transfer Period 


SYSCLK | ; 


REQ* : Same — tSRRF a: -—@- iSRRR 


a: = 1sDVv © ~- isDv 


Odd Number of SYSCLK Cycles per SCSI Synchronous Transfer Period 
SYSCLK | {| 


REQ’ >: --ISRRF >: :<#1SFRR 


i= 1SDV : —t- 1SDV 


SDBO0*:7*, SDBP* » 
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Initiator Mode Synchronous Data Transfers 


11.3.10.1 Data In Phase Timing Parameters 


SYMBOL PARAMETER MIN MAX UNITS 
tSDRS SDB0":7", SDBP" set-up time to REQ” L 40 ns 
tSDRH REQ" ! to SDB0":7", SDBP" hold time 100 ns 


11.3.10.2 Data In Phase Timing (AC29) 
REQ* 


SDB0*:7", SDBP*»> 
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11.3.10.3 Data Out Phase Timing Parameters 


SYMBOL PARAMETER MIN MAX UNITS 
tSRAF —sS SYSCLKT toACK’ldelay 45 rs 
tSRAR SYSCLK T to ACK’ T delay 45 ns 
1SFAR——“‘<«~SSYSCLK to ACK’ T delay = (ststi‘(‘Cé;é;étSS*~*~*~*~*~*~C<‘<(;<Cs;éCsSSC*~*”W 
tSDV SYSCLK T to SDBO":7", SDBP” valid delay 35 ns 
NOTES: 


For the Data Out phase, the SCSI data bus set-up and hold times in synchronous transfer 
mode are dependent on the SYSCLK period t, in ns, and the value P which sets the 
synchronous transfer rate in Register 43H/63H, Bits 4-7. 


If P is chosen as an even number then: 


SDBO':7°, SDBP* set-up time to REQ’ = . (t-15) 
SDB0":7", SDBP* hold time from REQ’ J = P .(t-5). 
lf P is chosen as an odd number then: ° 

SDBO0":7", SDBP* set-up time to REQ’ L = = . (t-15) 
SDBO0":7", SDBP* hold time from REQ’ J = a » (t-5). 
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11.3.10.4 Data Out Phase Timing (AC31) 


Even Number of SYSCLK Cycles per SCSI Synchronous Transfer Period 


ACK* Se! ~t- iSRAF >! <-ISRAR 


—: :~<- 1SDV BP ~<a iSDV 


SDB0*:7*, SDBP* > 


(AC32) Odd Number of SYSCLK Cycles per SCSI Synchronous Transfer Period 


ACK* >: <-{SRAF >: ~<EISFAR 


~:. ~<# SDV pp: ~<# iSDV 


SDBO0*:7*, SDBP* > ) 
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11.3.11 Vector Process 

11.3.11.1 Vector Process Timing Parameters 
SYMBOL PARAMETER MIN MAX UNITS 
tVDS VECTOR in valid to SYSCLK T 10 ns 
tVDH SYSCLK T to VECTOR in invalid 5 ns 
tVDOV SYSCLK T to VREADY out valid 10 25 ns 
tVEOV SYSCLK T to VERROR out valid 10 25 ns 
Ff 


11.3.11.2 Vector Process Timing 


SYSCLK 


<— tVD0V—- —<_— a 
tVEOV—t>: —<—_— tvVEOV— ~<A 


VERROR 
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12. SAMPLE PACKAGE 


12.1 100-Pin Quad Flat Pack (QFP) Sample Package 


13.85 Min ss 
14.15 Max or 


19.85 Min 
20.15 Max 


— 17.40 Min 
oo 19.20 Max 


2.60 Min 
2.80 Max . 


v 


| Ea Sa oe ena aE 
0.13 Min UU] 0° Min 


0.20 MarR A ae Mino ag ~~ & 12° Max 


0.40 Min 0.40 Max 2.70 Min 


1.50 Max 23.40 Min 3.15 a 
25.20 Max 


1.50 Min 
2.40 Max 


NOTE: Dimensions for the QFP package are in millimeters. 
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13. TYPICAL APPLICATION 


ADDRESS 


| MPURAM 
ADDRESS/DATA 
CONTROL & | 
SCSI DATA DATA RLL INTERFACE 
CL-SM331 


SCSI 
Bus | SCSI CONTROL 


ERROR CL-SM330 OPTICAL 
CORRECTION DEVICE DRIVE 
CONTROL 
BUFFER BUFFER 
ADDRESS DATA 


AND STATUS 
STATIC OR 


DYNAMIC RAM 
DATA BUFFER 


Single-Ended Direct SCSI System Implementation 


14. ORDERING INFORMATION 


Numbering Guide 


CL — SM331 — 24 QC —A 


CIRRUS Locic— | 
Storage, MO Disk Revision ? 
Part Number Temperature Range: 


Serial Data Rate: C = Commercial 
24 = 24 MHz 


Package Type: 
Q = Quad Flat Pack (QFP) 


t Contact CIRRUS LOGIC for up-to-date information on revisions. 


114 A SS WN ST SN STA GI SO April 1991 


CL-SM331 
SCSI Optical Disk Controller 


i 


NOTES 


CL-SM331 


Preliminary Data Sheet 


Direct Sales Offices 


Domestic 


N. CALIFORNIA 
San Jose 

TEL: 408/436-7110 
FAX: 408/437-8960 


S. CALIFORNIA 

Tustin | 
TEL: 714/258-8303 
FAX: 714/258-8307 


Thousand Oaks 
TEL: 805/371-5381 
FAX: 805/371-5382 


ROCKY MOUNTAIN 
AREA 

Boulder, CO 

TEL: 303/939-9739 
FAX: 303/440-5712 


The Company 


NORTH CENTRAL 
AREA 
Westchester, IL 
TEL: 708/449-7715 


FAX: 708/449-7804 


SOUTH CENTRAL 
AREA 

Austin, TX 

TEL: 512/794-8490 
FAX: 512/794-8069 


NORTHEASTERN 
AREA 

Andover, MA 

TEL: 508/474-9300 
FAX: 508/474-9149 


Philadelphia, PA 


TEL: 215/251-6881 . 


FAX: 215/651-0147 


SOUTH EASTERN 
AREA 

Boca Raton, FL 
TEL: 407/994-9883 
FAX: 407/994-9887 


Atlanta, GA 
TEL: 404/263-7601 


SINGAPORE — 
TEL: 65/3532122 


_ FAX: 65/3532166 


TAIWAN 

Taipei 

TEL: 886/2-718-4533 
FAX: 886/2-718-4526 


FAX: 404/729-6942 
UNITED KINGDOM 
Berkshire, England 


International TEL: 44/344-780-782 
GERMANY FAX: 44/344-761-429 
Herrsching 


TEL: 49/08152-2030 
FAX: 49/08152-6211 


JAPAN 
Kanagawa-Ken 

TEL: 81/462-76-0601 
FAX: 81/462-76-0291 


Cirrus Logic, Inc., produces high-integration peripheral controller circuits for mass storage, graphics, 
and data communications. Our products are used in leading-edge personal computers, engineering 
workstations, and office automation equipment. 


The Cirrus Logic formula combines proprietary S/LA™'* IC design automation with system design 
expertise. The S/LA design system is a proven tool for developing high-performance logic circuits in 
half the time of most semiconductor companies. The results are better VLSI products, on-time, that 
help you win in the marketplace. 


Cirrus Logic's fabless manufacturing strategy, unique in the semiconductor industry, employs a 
full manufacturing infrastructure to ensure maximum product quality, availability and value for our — 
customers. 


Talk to our systems and applications specialists; see how you can benefit from a new kind of 
semiconductor company. 


t+ U.S. Patent No. 4,293,783 © Copyright, Cirrus Logic, Inc., 1991 


Preliminary product information describes products which are in production, but for which full characterization data is not yet 
available. Cirrus Logic, Inc. believes the information contained in this document is accurate and reliable. However, it is marked 
Preliminary and is subject to change without notice. No responsibility is assumed by Cirrus Logic, Inc. for its use, nor for 
infringements of patents or other rights of third parties. This document implies no license under patents or copyrights. Trademarks 
in this document belong to their respective companies. Cirrus Logic, Inc. products are covered under one or more of the following 
U.S. patents: 4,293,783; Re. 31,287; 4,763,332; 4,777,635; 4,839,896; 4,931,946; 4,979,173. 


CIRRUS LOGIC, Inc., 3100 West Warren Ave. Fremont, CA 94538 


TEL: 415/623-8300 FAX: 415/226-2160 614331-001 


